没有合适的资源?快使用搜索试试~ 我知道了~
C++友元习题 .pdf
1.该资源内容由用户上传,如若侵权请联系客服进行举报
2.虚拟产品一经售出概不退款(资源遇到问题,请及时私信上传者)
2.虚拟产品一经售出概不退款(资源遇到问题,请及时私信上传者)
版权申诉
0 下载量 75 浏览量
2023-02-27
19:51:02
上传
评论
收藏 175KB PDF 举报
温馨提示
试读
11页
.
资源推荐
资源详情
资源评论
01. 分析以下程序的执行结果
#include<iostream.h>
class Sample
{
int n;
public:
Sample(int i){n=i;}
friend int add(Sample &s1,Sample &s2);
};
int add(Sample &s1,Sample &s2)
{
return s1.n+s2.n;
}
void main()
{
Sample s1(10),s2(20);
cout<<add(s1,s2)<<endl;
}
解:
此题说明了友元函数的使用方法。add()是一个友元函数,它返回两个引用对象的 n 值之和。
所以输出为: 30
注意:友元函数不是类的成元函数
----------------------------------------------------
02.分析以下程序的执行结果
#include<iostream.h>
class B;
class A
{
int i;
public:
int set(B&);
int get(){return i;}
A(int x){i=x;}
};
class B
{
int i;
public:
B(int x){i=x;}
friend A;
.
};
int A::set(B &b) // 由于使用了类 B 的定义,故本函数的定义应放在类 B 定义之后
{
return i=b.i;
}
void main()
{
A a(1);
B b(2);
cout<<a.get()<<",";
a.set(b);
cout<<a.get()<<endl;
}
解:
此题说明友元类的使用方法。这里将类 A 设置为类 B 的友元类,因此,类 A 的所有成员函数均为类 B
的友元函数。通过调用 a.set(b)将 b 对象的 i 值赋给 a 对象的 i 值。
所以输出为:1,2
-------------------------------------------------
03.有一个学生类 student,包括学生姓名、成绩,设计一个友元函数,比拟两个学生成绩的上下,并求
出最高分和最低分的学生。
解:
#include<iostream.h>
#include<string.h>
class student
{
char name[10];
int deg;
public:
student(char na[],int d)
{
strcpy(name,na);
deg=d;
}
char *getname(){ return name;}
friend int compare(student &s1,student &s2)
{
if(s1.deg>s2.deg)
return 1;
else if(s1.deg==s2.deg)
return 0;
else return -1;
.
}
};
void main()
{
student st[]={student("王华",78),student("李明",92),student("张伟",62),student("孙强",88)};
int i,min=0,max=0;
for(i=1;i<4;i++)
{
if(compare(st[max],st[i])==-1)
max=i;
else if(compare(st[i],st[min])==1)
min=i;
}
cout<<"输出结果:"<<endl;
cout<<" 最高分:"<<st[max].getname()<<endl;
cout<<" 最低分:"<<st[min].getname()<<endl;
}
本程序的执行结果如下:
输出结果:
最高分者:李明
最低分者:张伟
-------------------------------------------------------------
04.有一个学生类 student,包括学生姓名、成绩,设计一个友元函数,输出成绩对应的等级:大于等于
90:优;80~90:良;70~79:中;60!69:及格;小于 60:不及格。
解:
#include<iostream.h>
#include<string.h>
#include<iomanip.h>
class student
{
char name[10];
int deg;
char level[7];
public:
student(char na[],int d)
{
strcpy(name,na);
deg=d;
}
char *getname(){ return name;}
friend void trans(student &s)
.
剩余10页未读,继续阅读
资源评论
xxpr_ybgg
- 粉丝: 6492
- 资源: 3万+
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
最新资源
- 高德地图AMap-adcode-citycode
- 123111111111111
- PDF加密转APK大师1.0.0(解压密码1234)
- ProSP3.CD-ROM.iso
- 六一儿童节主题-少儿编程教学-scratch游戏demo设计
- main.m
- 基于Python.Numpy实现BP卷积神经网络识别手写数字源码(含超详细注释+使用说明).zip
- 个人 ACM 的 Wiki的静态网站.zip
- 基于Python.Numpy实现BP卷积神经网络识别手写数字源码(含超详细注释+使用说明).zip
- opencv4.8.0-opencv4.9.0-opencv-contrib4.8.0-opencv-contrib4.9.0
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功