C++面向对象程序设计的一些作业文档格式.docx
- 文档编号:20778591
- 上传时间:2023-01-25
- 格式:DOCX
- 页数:76
- 大小:33.96KB
C++面向对象程序设计的一些作业文档格式.docx
《C++面向对象程序设计的一些作业文档格式.docx》由会员分享,可在线阅读,更多相关《C++面向对象程序设计的一些作业文档格式.docx(76页珍藏版)》请在冰豆网上搜索。
endl;
return0;
}
试题查看
2、求3个数的平均值
从键盘上输入3个浮点数,求这3个数的平均值。
3个浮点数
3个数的平均值
1.51.61.3
1.46667
1、用usingnamespacestd;
明确名字空间
2、用cin对象,采用>
>
运算符输入数据
3、用cout对象,采用<
运算符输出数据
doublea,b,c,d;
cin>
a>
b>
c;
d=(a+b+c)/3;
cout<
d<
endl;
3、求鞍点
输入一个二维矩阵。
找出其中所有的鞍点,如果一个矩阵没有鞍点,输出“Notfound!
所谓“鞍点”,是指满足以下条件的矩阵中的一个数,它在它所在的行上最小、所在列上最大。
该题中假设矩阵中任意两个数互不相等。
输入数据有多行:
第一行是矩阵的行数m和列数n
从第二行起共包含m行,每行包含n个数,为矩阵的一行数据
如果矩阵有鞍点,输出鞍点的信息,包括:
所在行、所在列、值
如果没有鞍点,输出Notfound!
34
11235647
12456690
16773418
2
16
1、要求用动态内存分配来完成,可用new和delete实现;
2、屏幕输出只有2016(加回车换行),不能有其它信息。
intm,n,i,j,k;
int**x;
introwmin,linkmax,codr=0,codl=0;
m>
n;
x=newint*[m];
for(i=0;
i<
m;
i++)
x[i]=newint[n];
for(i=0;
{
for(j=0;
j<
j++)
x[i][j];
}
rowmin=x[0][0];
rowmin=x[i][0];
codl=0;
codr=i;
//codl=0;
if(x[i][j]<
rowmin)
rowmin=x[i][j];
codl=j;
//cout<
rowmin<
x[codr][codl]<
gfyf"
for(k=0;
k<
k++)
if(x[k][codl]>
//cout<
codl=-1;
break;
//elsecout<
x[k][codl]<
变"
;
if(codl!
=-1)
codr<
codl<
elsecout<
Notfound!
4、链表操作
建立一个链表,每个节点包括学生的学号、姓名、性别、年龄。
先输入5个学生的数据,再输入一个年龄,如果链表中有年龄等于此年龄的记录,则删除所有年龄等于此年龄的记录,否则在链表的最后增加一个新节点,学号为180姓名为"
aaa"
,性别为"
male"
。
创建链表时输入5个职工的职工号和工资,学号为大于100且小于200的整数,姓名为长度小于20的字符串,性别为长度小于10的字符串,年龄为大于等于0且小于200的整数。
按顺序输出链表中的所有数据,每个数据占一行。
101zhangsanmale30
103lisifemale18
105wangwumale25
107maliumale28
109niuqifemale22
28
101
zhangsan
male
30
103
lisi
female
18
105
wangwu
25
109
niuqi
22
要求用动态内存分配实现,注意new和delete的使用。
stdio.h>
cstring>
typedefstructData
int_number;
string_name;
string_sex;
int_age;
}Data;
typedefstructNode
Data_data;
structNode*next;
}Node,*LinkList;
//类的声明
classLinkListed
private:
LinkListList;
public:
LinkListed()
List=newNode();
List->
next=NULL;
~LinkListed()
if(List==NULL)
return;
else
while(List!
=NULL)
LinkListp=List;
List=List->
next;
deletep;
voidCreate()
List=newNode();
LinkListp,q;
q=List;
for(inti=0;
5;
p=newNode();
p->
_data._number>
_data._name>
_data._sex>
_data._age;
q->
next=p;
q=p;
voidIns(intnum,stringname,stringsex,intage)
p=List->
while(p->
next)
p=p->
q=newNode();
_data._number=num;
_data._name=name;
_data._sex=sex;
_data._age=age;
p->
next=q;
voidSearch(inta)
LinkListp=List,q;
intn=0;
while(p)
if(p->
_data._age==a)
n++;
if(n==0)
charname[20]="
chargender[10]="
Ins(180,name,gender,a);
for(q=List;
q->
next!
=p;
q=q->
next){}
next=p->
p=q;
voiddisplay()
LinkListp=List->
_data._number<
endl<
_data._name<
_data._sex<
_data._age<
};
inta;
LinkListedL;
L.Create();
a;
L.Search(a);
L.display();
实验二
1.函数重载
设计一菜单程序,利用函数重载实现员工月工资的计算,计算方法如下:
(1)管理人员的月工资=月薪-缺勤天数×
月薪÷
22;
(2)销售人员的月工资=底薪+销售金额×
提成比例;
(3)计件工人的月工资=产品件数×
每件报酬;
(4)计时工人的月工资=工作小时×
小时报酬;
职工类别。
管理人员输入月薪和缺勤天数;
销售人员输入底薪、销售金额和提成比例;
计件工人输入产品件数和每件报酬;
计时工人输入工作小时和小时报酬。
员工月工资。
1〈--职工类别
5000.01〈--月薪和缺勤天数
4772.73
1.计算管理人员、销售人员、计件工人、计时工人的月工资的函数原型可以分别设计如下:
doublegetEarning(doublesalary,intabsenceDays);
doublegetEarning(doublebaseSalary,doublesalesSum,doublerate);
doublegetEarning(intworkPieces,doublewagePerPiece);
doublegetEarning(doublehours,doublewagePerHour);
2.菜单程序设计如下:
...
Pleaseselect..."
1:
Manager."
2:
SalesMan."
3:
PiecesWorker."
4:
Hour-Worker."
Others:
Quit"
cin>
sel;
switch(sel)
case1:
...;
getEarning(...);
case2:
case3:
case4:
default:
doublegetEarning(doublesalary,intabsenceDays)
return(salary-salary*absenceDays/22);
doublegetEarning(doublebaseSalary,doublesalesSum,doublerate)
return(baseSalary+salesSum*rate);
doublegetEarning(intworkPieces,doublewagePerPiece)
return(workPieces*wagePerPiece);
doublegetEarning(doublehours,doublewagePerHour)
return(hours*wagePerHour);
intsel,workPieces,absenceDays;
doublesalary,baseSalary,salesSum,rate,wagePerPiece,hours,wagePerHour;
salary>
absenceDays;
getEarning(salary,absenceDays);
baseSalary>
salesSum>
rate;
getEarning(baseSalary,salesSum,rate);
workPieces>
wagePerPiece;
getEarning(workPieces,wagePerPiece);
hours>
wagePerHour;
getEarning(hours,wagePerHour);
2.引用传递
设计一个函数,将两个浮点数传入,然后通过引用把其和、差、积传出。
函数原型如下:
voidMath(floata,floatb,float&
sum,float&
sub,float&
pro);
输入两个浮点数
输出两个浮点数的和、差、积。
6.52.3
8.84.214.95
法二:
pro)
sum=a+b;
sub=a-b;
pro=a*b;
floata,b,sum,sub,pro;
sum=sub=pro=0;
b;
Math(a,b,sum,sub,pro);
sum<
sub<
pro<
3.函数模板
设计一个函数模板,实现两个同类型数据的交换。
将设计好的函数模板分别实例化为两个整型数交换、两个字符交换的模板函数,调用这些函数并输出运行结果。
分别输入两个整型数和两个字符
分别输出两个整型数和两个字符交换的结果
59
95
template<
classType>
Typechange(Typea,Typeb)
Typec;
c=a;
a=b;
b=c;
a<
b<
inta,b;
stringc,d;
c>
d;
change<
int>
(a,b);
string>
(c,d);
4.默认形参值
设计一个求空间两点距离的函数,要求第2个点的默认值为坐标原点。
两个点的坐标。
输出第一个点与原点之间的距离及输入的两个点之间的距离。
111
555
1.73205
6.9282
函数原型可设计如下:
floatdistance(floatx1,floaty1,floatz1,floatx2=0,floaty2=0,floatz2=0);
#include<
math.h>
classpoint
floatx,x1;
floaty,y1;
floatz,z1;
floatdistance1()//类的
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- C+ 面向 对象 程序设计 一些 作业