C 习题和解析(友元-04)
2008-02-23 05:34:29来源:互联网 阅读 ()
解:
将原来求两个点的距离的普通函数distance()改写为友元函数即可,能够看到采用友元函数方法使得代码更简洁。
本题程式如下:
#include<iostream.h>
#include<math.h>
class Point
{
int x,y;
public:
Point(int i,int j){x=i;y=j;}
friend float distance(Point &p1,Point &p2);
void disp()
{
cout<<"("<<x<<","<<y<<")";
}
};
float distance(Point &p1,Point &p2) // 友元函数的实现
{
float d;
d=sqrt((p1.x-p2.x)*(p1.x-p2.x) (p1.y-p2.y)*(p1.y-p2.y));
return d;
}
void main()
{
Point p1(2,2),p2(5,5);
p1.disp(); cout<<"和"; p2.disp();
cout<<"之间距离="<<distance(p1,p2)<<endl;
}
本程式执行结果如下:
(2,2)和(5,5)之间距离=4.24264
-------------------------------------------------------
题7.设计一个日期类Date,包括日期的年份、月份和日号,编写一个友元函数,求两个日期之间相差的天数。
解:
该类中设计有3个友元函数;count_day()函数,他有两个参数,第2个参数是个标志,当其值等于1 时,计算一年的开始到某日期的天数;否则计算某日期到年尾的天数。leap()函数用于判断指定的年份是否为闰年。subs()函数用于计算两个日期之间的天数。
本题程式如下:
#include<iostream.h>
#include<stdio.h>
class Date
{
int year;
int month;
int day;
public:
Date(int y,int m,int d)
{
year=y;month=m;day=d;
}
void disp()
{
printf("%d.%d.%d",year,month,day);
}
friend int count_day(Date &d,int);
friend int leap(int year);
friend int subs(Date &d1,Date &d2);
};
int count_day(Date &d,int flag)
{
static int day_tab[2][12]={{31,28,31,30,31,30,31,31,30,31,30,31},
{31,29,31,30,31,30,31,31,30,31,30,31}};
// 使用二维数组存放各月天数,第一行对应非闰年,第二行对应闰年
int p,i,s;
if(leap(d.year))
p=1;
else p=0;
if(flag)
{
s=d.day;
for(i=1;i<d.month;i )
s =day_tab[p][i-1];
}
else
{
s=day_tab[p][d.month]-d.day;
for(i=d.month 1; i<=12; i )
s =day_tab[p][i-1];
}
return s;
}
int leap(int year)
{
if(year%4==0&&year0!=0||year@0==0) // 是闰年
return 1;
else // 不是闰年
return 0;
}
int subs(Date &d1,Date &d2)
{
int days,day1,day2,y;
if(d1.year<d2.year)
{
days=count_day(d1,0);
for(y=d1.year 1; y<d2.year ;y )
if(leap(y))
days =366L;
else
days =365L;
days =count_day(d2,1);
}
else if(d1.year==d2.year)
{
day1=count_day(d1,1);
day2=count_day(d2,1);
days=day2-day1;
}
else
days=-1;
return days;
}
void main()
{
Date d1(2000,1,1),d2(2002,10,1);
int ds=subs(d1,d2);
printf("输出结果:\n ");
if(ds>=0)
{
d1.disp(); printf("和");
d2.disp(); printf("之间有%d天\n\n",ds);
}
else
printf("时间错误!\n");
}
本程式的执行结果如下:
输出结果:
2000.1.1和2002.10.1之间有1002天
-------------------------------------------------------
题8.编写一个程式,设计一个Point类,包括学号、姓名和成绩等私有数据成员,不含任何成员函数,只将main()配置为该类的友元函数。
解:
main()函数和其他的函数相同能够配置为类的友元函数,这样就能够在其中使用类对象的私有数据成员。
本题的程式如下:
#include<iostream.h>
class Person
{
int no;
char name[10];
int deg;
public:
friend void main();
};
void main()
{
Person obj;
cout<<"输入学号:";
cin>>obj.no;
cout<<"姓名:";
cin>>obj.name;
cout<<"成绩:";
cin>>obj.deg;
cout<<"输出结果"<<endl;
cout<<"学生"<<obj.name<<"(学号"<<obj.no<<")成绩为"<<obj.deg<<endl;
}
本程式执行结果如下:
输入学号: 10
姓名: Zhengming
成绩:88
输出结果
学生Zhengming(学号10)成绩为88
-------------------------------------------------------
题9.采用友元类的方式重新编写“友元第04题“的程式。
解:
将原student类中的disp()成员函数和trans()友元函数作为友元类process的成员函数。其执行结果和第4题的结果完全相同。
本题程式如下:
#include<iostream.h>
#include<string.h>
#include<iomanip.h>
class student
{
char name[10];
int deg;
char level[7];
friend class process; // 说明友元类
public:
student(char na[],int d)
{
strcpy(name,na);
deg=d;
}
};
class process
{
public:
void trans(student &s)
{
if(s.deg>=90)
strcpy(s.level,"优");
else if(s.deg>=80)
strcpy(s.level,"良");
else if(s.deg>=70)
strcpy(s.level,"中");
else if(s.deg>=60)
strcpy(s.level,"及格");
else
strcpy(s.level,"不及格");
}
void disp(student &s)
{
cout<<setw(10)<<s.name<<setw(6)<<s.deg<<setw(8)<<s.level<<endl;
}
};
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
上一篇: C 习题和解析(友元-02)
下一篇: C 习题和解析(重载-02)
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash