C++友元习题Word格式文档下载.docx
- 文档编号:16925777
- 上传时间:2022-11-27
- 格式:DOCX
- 页数:16
- 大小:17.52KB
C++友元习题Word格式文档下载.docx
《C++友元习题Word格式文档下载.docx》由会员分享,可在线阅读,更多相关《C++友元习题Word格式文档下载.docx(16页珍藏版)》请在冰豆网上搜索。
);
intget(){returni;
A(intx){i=x;
classB
B(intx){i=x;
friendA;
intA:
:
set(B&
b)//由于使用了类B的定义,故本函数的定义应放在类B定义之后
returni=b.i;
Aa
(1);
Bb
(2);
a.get()<
"
"
;
a.set(b);
本题说明友元类的使用方法。
这里将类A设置为类B的友元类,因此,类A的所有成员函数均为类B
的友元函数。
通过调用a.set(b)将b对象的i值赋给a对象的i值。
1,2
-------------------------------------------------
03.有一个学生类student,包括学生姓名、成绩,设计一个友元函数,比较两个学生成绩的高低,并求
出最高分和最低分的学生。
string.h>
classstudent
charname[10];
intdeg;
student(charna[],intd)
strcpy(name,na);
deg=d;
char*getname(){returnname;
friendintcompare(student&
s1,student&
if(s1.deg>
s2.deg)
return1;
elseif(s1.deg==s2.deg)
return0;
elsereturn-1;
studentst[]={student("
王华"
78),student("
李明"
92),student("
张伟"
62),student("
孙强"
88)};
inti,min=0,max=0;
for(i=1;
i<
4;
i++)
if(compare(st[max],st[i])==-1)
max=i;
elseif(compare(st[i],st[min])==1)
min=i;
输出结果:
最高分:
st[max].getname()<
最低分:
st[min].getname()<
本程序的执行结果如下:
输出结果:
最高分者:
李明
最低分者:
张伟
-------------------------------------------------------------
04.有一个学生类student,包括学生姓名、成绩,设计一个友元函数,输出成绩对应的等级:
大于等于
90:
优;
80~90:
良;
70~79:
中;
60!
69:
及格;
小于60:
不及格。
iomanip.h>
charlevel[7];
friendvoidtrans(student&
s)
if(s.deg>
=90)
strcpy(s.level,"
优"
elseif(s.deg>
=80)
良"
=70)
中"
=60)
及格"
else
不及格"
voiddisp()
setw(10)<
name<
setw(6)<
deg<
setw(8)<
level<
姓名"
成绩"
等级"
02.05.设计一个类Sample,它有两个私有成员A[]和n(A中元素个数),将对A[]中数据进行各种排序的函数
放入到一个友元类process中。
process类不包含任何数据成员,包含的公共成员函数如下:
getdata(Sample&
s);
用于获取对象s的数据
insertsort(Sample&
用于进行插入排序
shellsort(Sample&
用于进行希尔排序
bubblesort(Sample&
用于进行冒泡排序
quicksort(Sample&
用于进行快速排序
selectsort(Sample&
用于进行选择排序
disp(Sample&
用于输出数据
本题程序如下:
#defineMax100
intA[Max];
friendclassprocess;
Sample(){n=0;
classprocess
voidqsort(Sample&
s,intl,inth);
//私有成员,由quicksort()成员调用
voidgetdata(Sample&
voidinsertsort(Sample&
voidshellsort(Sample&
voidbubblesort(Sample&
voidquicksort(Sample&
voidselectsort(Sample&
voiddisp(Sample&
voidprocess:
元素个数:
cin>
>
s.n;
for(i=0;
s;
输入第"
i+1<
个数据:
s.A[i];
s)//插入排序
inti,j,temp;
temp=s.A[i];
j=i-1;
while(temp<
s.A[j])
s.A[j+1]=s.A[j];
j--;
s.A[j+1]=temp;
s)//希尔排序
inti,j,gap,temp;
gap=s.n/2;
while(gap>
0)
for(i=gap;
j=i-gap;
while(j>
=gap)
if(s.A[j]>
s.A[j+gap])
temp=s.A[j];
s.A[j]=s.A[j+gap];
s.A[j+gap]=temp;
j=j-gap;
elsej=0;
gap=gap/2;
s)//冒泡排序
for(j=s.n-1;
j>
=i+1;
j--)
if(s.A[j]<
s.A[j-1])
s.a[j]=s.A[j-1];
s.A[j-1]=temp;
s)//快速排序
qsort(s,0,s.n-1);
qsort(Sample&
s,intl,inth)
inti=l,j=h,temp;
if(l<
h)
{temp=s.A[l];
do
i&
&
s.A[j]>
=temp)
if(i<
j)
s.A[i]=s.A[j];
i++;
while(i<
j&
s.A[i]<
s.A[j]=s.A[i];
}while(i<
j);
s.A[i]=temp;
qsort(s,l,j-1);
qsort(s,j+1,h);
s)//选择排序
inti,j,k,temp;
k=i;
for(j=i+1;
j<
=s.n-1;
j++)
s.A[k])
k=j;
s.A[i]=s.A[k];
s.A[k]=temp;
for(inti=0;
intsel;
Samples;
processp;
p.getdata(s);
原来序列:
p.disp(s);
0:
插入排序1:
希尔排序2:
冒泡排序3:
快速排序4:
选择排序其它退出"
选择排序方法:
sel;
switch(sel)
case0:
p.insertsort(s);
插入排序结果:
03.题1.分析以下程序的执行结果
Sample(){}
Sample(intm){n=m;
friendvoidsquare(Sample&
s.n=s.n*s.n;
n="
n<
Samplea(10);
square(a);
a.disp();
本题应用友元函数修改对象的数据成员。
square()是一个友元函数,它将引用对象的n值进行平方计算。
100
-----------------------------------------------------------
题2.分析以下程序的执行结果
friendB;
voiddisp(){cout<
voidset(intn)
Aa;
a.i=n;
//i是对象a的私有数据成员,在友元类可以使用
//disp()是对象a的私有成员函数,在友元类可以使用
Bb;
b.set
(2);
本题说明友元类的设计方法。
这里将类B设置为类A的友元类,因此,在设计类B时可以直接使用类
A的私有数据成员和成员函数。
2
题3.分析以下程序的执行结果
classteacher;
char*name;
student(char*s){name=s;
friendvoidprint(student&
teacher&
classteacher
teacher(char*s){name=s;
voidprint(student&
a,teacher&
b)
thestudentis:
a.name<
theteacheris:
b.name<
students("
LiHu"
teachert("
WangPing"
print(s,t);
student和teacher类共用一个友元函数的实现。
thestudentisLiHu
theteacherisWanPing
--------------------------------------------------------------
题4.有一个学生类student,包括学生姓名、成绩,设计一个友元类,输出成绩大于等于80分以上者。
学生类student的disp()函数设计成友元函数。
friendvoiddisp(student&
s.name<
s.deg<
disp(st[i]);
姓名成绩
李明92
孙强88
题5.有一个向量类Vector,包括一个点的坐标位置x和y,设计两个友元函数,实现两个向量的加法和
减法的运算
classVector
intx,y;
Vector(){}
Vector(inti,intj){x=i;
y=j;
("
x<
y<
)"
friendVectoradd(Vector&
v1,Vector&
v2)
Vectorv;
v.x=v1.x+v2.x;
v.y=v1.y+v2.y;
returnv;
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- C+ 习题
![提示](https://static.bdocx.com/images/bang_tan.gif)