永发信息网

各位师兄师姐,俺正在学C++,跪求赐教,请进!!!!!

答案:4  悬赏:70  手机版
解决时间 2021-11-12 06:59
各位师兄师姐,俺正在学C++,跪求赐教,请进!!!!!
最佳答案
题6.阅读下面的程序与输出结果,添加一个拷贝构造函数来完善整个程序
#include
class Cat
{
public:
Cat();
Cat(const Cat &);
~Cat();
int getage()const{return *itsage;}
void setage(int age){*itsage=age;}
protected:
int *itsage;
};
Cat::Cat()
{
itsage=new int;
*itsage=5;
}
Cat::~Cat()
{
delete itsage;
itsage=0;
}
void main()
{
Cat frisky;
cout<<"frisky's age:"<cout<<"setting frisky to 6...\n";
frisky.setage(6);
cout<<"creating boots from frisky\n";
Cat boots(frisky);
cout<<"frisky's age:"<cout<<"boots'age:"<cout<<"setting frisky to 7...\n";
frisky.setage(7);
cout<<"frisky's age:"<cout<<"boots'age:"<}

当添加了拷贝构造函数后,程序的运行结果为:
frisky's age:5
setting frisky to 6...
creating boots from frisky
frisky's age:6
boots'age:6
setting frisky to 7...
frisky's age:7
boots'age:6

解:
添加的拷贝构造函数如下:
Cat::Cat(const Cat& c)
{
itsage=new int;
*itsage=*c.itsage;
}

-----------------------------------------------

题7.设计一个类Sample,有一个私有数据成员,建立该类的四个对象s1(n=10)、s2(n=20)、s3(n=30)、和s4(n=40),建立一个成员函数实现这些对象n值的累加。
解:
依题意,建立一个成员函数add(),其参数为Sample对象引用,用于累加对象n值。
程序如下:
#include
class Sample
{
int n;
public:
Sample(){}
Sample (int i){n=i;}
void add(Sample &s) // 对象引用作为参数
{
if(&s==this) // 不能自己相加,this是当前对象的指针
cout<<"自己不能相加"<else n+=s.n;
}
void disp(){ cout<}
};
float distance(Point &p1,Point &p2) // 对象引用作为参数
{
float d;
d=sqrt((p1.getx()-p2.getx())*(p1.getx()-p2.getx())+
(p1.gety()-p2.gety())*(p1.gety()-p2.gety()));
return d;
}
void main()
{
Point p1(2,2),p2(5,5);
p1.disp(); cout<<"与"; p2.disp();
cout<<"之间距离="<}

本程序执行结果如下
(2,2) 与 (5,5) 之间距离=4.24264

-----------------------------------------------------

题9.编写一个程序,设计一个职工类Person,一个系有若干个职工,按职务分为系主任、室主任和职工,给出他们之间的领导关系。
解:
类Person有姓名、职务和指向领导的指针等私有数据,以及两个构造函数和以下成员函数:setleader()(设置当前职工的领导);getname()(获取职工姓名);getleader()(获取领导者对象指针);disp()(输出姓名和职务)。
本题程序如下:
#include
#include
#include
class Person
{
char name[10];
char prof[10];
Person *leader;
public:
Person(){strcpy(name,"\0");}
Person(char n[],char p[])
{
strcpy(name,n);
strcpy(prof,p);
leader=new Person;
}
void setleader(Person &p){leader=&p;} // 对象引用作为参数
char *getname(){ return name;}
Person *getleader()
{
return leader;
}
void disp()
{
printf("%10s %10s%",name,prof);
}
};
void main()
{
Person p[]={Person("王华","室主任"),Person("李明","职工"),
Person("陈强","系主任"),Person("章城","职工"),
Person("张伟","室主任"),Person("许源","职工")};
p[0].setleader(p[2]);
p[1].setleader(p[0]);
p[3].setleader(p[4]);
p[4].setleader(p[2]);
p[5].setleader(p[4]);
printf(" 姓名 职务 领导姓名\n");
printf("------------------------------\n");
for(int i=0;i<6;i++)
{
p[i].disp();
printf("%10s\n",(p[i].getleader())->getname());
}
}

本程序的执行结果如下:
姓名 职务 领导姓名
----- ------ -------
王华 室主任 陈强
李明 职工 王华
陈强 系主任
章城 职工 张伟
张伟 室主任 陈强
许源 职工 张伟

C++习题与解析(模板-03)

题 5. 一个Sample类模板的私有数据成员为T n,在该类模板中设计一个operator==重载运算符函数 ,用于比较各对象的n数据是否相等。
解:
本题程序如下:
#include
template
class Sample
{
T n;
public:
Sample(T i){n=i;}
int operator==(Sample &);
};
template
int Sample::operator==(Sample &s)
{
if(n==s.n)
return 1;
else
return 0;
}
void main()
{
Sample s1(2),s2(3);
cout<<"s1与s2的数据成员"<<(s1==s2?"相等":"不相等")<Samples3(2.5),s4(2.5);
cout<<"s3与s4的数据成员"<<(s3==s4?"相等":"不相等")<}
本程序的运行结果如下:
s1与s2的数据成员不相等
s3与S4的数据成员相等

----------------------------------------------------

题 6. 对第3章的例3.5进行修改,只设计一个Sample类,其数据和方法均包含在该类中,而且使用类模板的方式实现。
#include
#define Max 100
template
class Sample
{
T A[Max];
int n;
void qsort(int l,int h); // 私有成员,由quicksort()成员调用
public:
Sample(){n=0;}
void getdata(); // 获取数据
void insertsort(); // 插入排序
void Shellsort(); // 希尔排序
void bubblesort(); // 冒泡排序
void quicksort(); // 快速排序
void selectsort(); // 选择排序
void disp();
};
template
void Sample::getdata()
{
cout<<"元素个数:";
cin>>n;
for(int i=0;i{
cout<<"输入第"<cin>>A[i];
}
}
template
void Sample::insertsort() // 插入排序
{
int i,j;
T temp;
for(i=1;i{
temp=A[i];
j=i-1;
while(temp{
A[j+1]=A[j];
j--;
}
A[j+1]=temp;
}
}
template
void Sample::Shellsort() // 希尔排序
{
int i,j,gap;
T temp;
gap=n/2;
while(gap>0)
{
for(i=gap;i{
j=i-gap;
while(j>=gap)
if(A[j]>A[j+gap])
{
temp=A[j];
A[j]=A[j+gap];
A[j+gap]=temp;
j=j-gap;
}
else j=0;
}
gap=gap/2;
}
}
template
void Sample::bubblesort() // 冒泡排序
{
int i,j;
T temp;
for(i=0;ifor(j=n-1;j>=i+1;j--)
if(A[j]{
temp=A[j];
A[j]=A[j-1];
A[j-1]=temp;
}
}
template
void Sample::quicksort() // 快速排序
{
qsort(0,n-1);
}
template
void Sample::qsort(int l,int h)
{
int i=l,j=h;
T temp;
if(l{
temp=A[l];
do{
while(j>i&&A[j]>=temp)
j--;
if(i{
A[i]=A[j];
i++;
}
while(ii++;
if(i{
A[j]=A[i];
j--;
}
}while(iA[i]=temp;
qsort(1,j-1);
qsort(j+1,h);
}
}
template
void Sample::selectsort() // 选择排序
{
int i,j,k;
T temp;
for(i=0;i{
k=i;
for(j=i+1;j<=n-1;j++)
if(A[j]k=j;
temp=A[i];
A[i]=A[k];
A[k]=temp;
}
}
template
void Sample::disp()
{
for(int i=0;icout}
void main()
{
int sel=0;
Sample s; // 由类模板产生char型的模板类
s.getdata();
cout<<"原来序列:";
s.disp();
cout<<"0:插入排序 1:希尔排序 2:冒泡排序 3:快速排序\n 4:选择排序 其它退出"<cout<<"选择排序方法:";
cin>>sel;
switch(sel)
{
case 0:
s.insertsort();
cout<<"插入排序结果";
break;
case 1:
s.Shellsort();
cout<<"希尔排序结果:";
break;
case 2:
s.bubblesort();
cout<<"冒泡排序结果:";
break;
case 3:
s.quicksort();
cout<<"快速排序结果:";
break;
case 4:
s.selectsort();
cout<<"选择排序结果:";
break;
}
s.disp();
}
程序运行结果如下:
全部回答
我有14本这样的书,电子档的,要的话,可以发给你.

参考资料:俺是南京邮电大学的,我的QQ:631734620 573045625

出题目啊
自己网上找啊,
别跟人要题啊!
自己编题要,解决实际问题就是最好的练习。
看看你周围,都有什么。一切用数据描述。
比如你班里的同学。编一个软件来描述班里同学的行为。
我要举报
如以上问答信息为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
大家都在看
日本封面模特小松彩夏和日本著名球星永井谦佑
已知G的邻接矩阵为A(G)=的问题,请看补充
打蛇哪最好?
お买い物金额は合计で3万円になります 求翻译
在一个长50m,宽30m的荒地上建造花坛,为了使
350kw。380伏、需要多大电缆?多大开关?
和是12的而且是3个数的还要俩个数加起来是对
风骚在古文中的意思是什么?
品胜双usb充电器是否有苹果和安卓两个版本
宁波市花园园林建设有限公司龙岩分公司怎么样
请问,卫生间的马桶位置可以更换吗?
用什么灯可以把字射在墙上
炫彩广告地址好找么,我有些事要过去,
5公分厚岩棉板多少钱一平米
战神z6-kp5gt是蓝天模具吗
推荐资讯
iphone版《鬼泣4》探索弗杜那城怎么进不了最
无锡蠡湖公园渔公岛沙滩水边为什么要在岸边圈
用简便方法计算152+629+848
坊子四中和昌乐一中哪个高中比较好
这样的小区能开干洗店吗?
5%卵清蛋白溶液与ph4.7的缓冲溶液等量混合有
好老婆好生活合法吗,是直传销吗?上下线模式
若英国脱欧成功的话,对欧盟有什么影响
本溪天宏旅店地址好找么,我有些事要过去,
如果一个男生总是偷偷看一个女生表示什么?
昕动1.4L汽车哪些配
请问深圳宝安25区那里有谭木匠店???
正方形一边上任一点到这个正方形两条对角线的
阴历怎么看 ?