C++经典习题

1、 设计一个立方体类BOX,它能计算并输出立方体的体积和表面积。

提示:定义一个BOX类,含有一个私有数据成员(立方体边长length),有两个公有数据函数(构造

函数Box和计算输出函数show

/** * 立方体类 * 作者:hellostory * 日期:2010-11-23 */ #include <iostream> using namespace std; class Box { private: double length; //立方体边长 double volume; //体积 double area; //表面积 public: /* * 构造函数 */ Box(double l) { length = l; volume = 0.0; area = 0.0; } /* * 计算体积 */ double getVolume() { return length * length * length; } /* * 计算表面积 */ double getArea() { return length * length * 6; } /* * 输出立方体体积和表面积 */ void show() { volume = getVolume(); area = getArea(); cout<<"立方体的体积:"<<volume<<",表面积:"<<area<<endl; } }; /* * 主函数 */ int main() { int length = 0; cout<<"请输入立方体的边长:"; cin>>length; Box box(length); box.show(); getchar(); return 0; }

2、 5个学生,每个学生的数据包括学号、姓名、三门课成绩,从键盘输入5个学生的数据,要求计算并输出。

1) 每个学生三门课的总成绩

2) 三门课每门课程的平均成绩

/** * 学生成绩管理 * 作者:hellostory * 日期:2010-11-23 */ #include<string> #include<iostream> using namespace std; #define N 5 //定义常量N=5 // 定义学生结构体 typedef struct { string no; //学号 string name; //姓名 float chinese; //语文 float math; //数学 float english; //英语 float total; //总成绩 }Student; // 定义5个学生 Student stu[N]; /* * 录入每个学生的成绩等 */ void input(int n) { string no; //学号 string name; //姓名 float chinese; //语文 float math; //数学 float english; //英语 for(int i=0; i!=n; i++) { cout<<"请输入第"<<i+1<<"个学生的学号:"; cin>>no; stu[i].no = no; cout<<"请输入该学生的姓名:"; cin>>name; stu[i].name = name; cout<<"请输入该学生语文成绩:"; cin>>chinese; stu[i].chinese = chinese; cout<<"请输入该学生数学成绩:"; cin>>math; stu[i].math = math; cout<<"请输入该学生英语成绩:"; cin>>english; stu[i].english = english; // 计算该学生三门课的总成绩 stu[i].total = stu[i].chinese + stu[i].math + stu[i].english; } } /* * 打印三门课每门课程的平均成绩 */ void printAvg() { int i = 0; float sumChinese=0, sumMath=0, sumEnglish=0; float avgChinese=0, avgMath=0, avgEnglish=0; for(i=0; i<N; i++) { sumChinese += stu[i].chinese; sumMath += stu[i].math; sumEnglish += stu[i].english; } avgChinese = sumChinese / N; avgMath = sumMath / N; avgEnglish = sumEnglish / N; cout<<"语文课:"<<avgChinese<<"\r\n"; cout<<"数学课:"<<avgMath<<"\r\n"; cout<<"英语课:"<<avgEnglish<<"\r\n"; } /* * 主函数 */ void main() { // 录入每个学生的成绩等 input(N); cout<<"\r\n---------- 统计结果 ----------\r\n"; cout<<"以下是每个学生三门课的总成绩:"<<"\r\n"; for (int i=0; i<N; i++) { cout<<stu[i].name<<":"<<"\t"<<stu[i].total<<"\r\n"; } cout<<"\r\n以下是每门课的平均成绩:"<<"\r\n"; printAvg(); // 接收多余的"\r\n" getchar(); getchar(); }

3、 假定居民的基本数据包括身份证号、姓名、性别和出生日期,而居民中的成年人又多项数据:最高学历和职业,成年人中的党员又多一项数据:党员类别。现要求建立三个类,让成年人类继承居民类,而党员类继承成年人类,并要求在每个类中都提供有数据输入和输出的功能。

/** * C++类继承 * 作者:hellostory * 日期:2010-11-23 */ #include<string> #include<iostream> using namespace std; /* * 居民类 */ class People { private: char id[19]; //身份证号 char name[11]; //姓名 char sex[4]; //性别 char birth[11]; //出生日期 public: void input() { cout<<"请按顺序(身份证号、姓名、性别、出生日期--用回车隔开)输入居民信息:"<<endl; cin>>id>>name>>sex>>birth; } void output() { cout<<id<<' '<<name<<' '<<sex<<' '<<birth<<endl; } }; /* * 成人类 */ class Adult: public People { private: char education[11]; //最高学历 char job[11]; //职业 public: void input() { People::input(); cout<<"请输入最高学历和职业(用回车隔开):"<<endl; cin>>education>>job; } void output() { People::output(); cout<<education<<' '<<job<<endl; } }; /* * 党员类 */ class Party: public Adult { private: char parties[15]; //党员类别 public: void input() { Adult::input(); cout<<"请输入党员类别:"<<endl; cin>>parties; } void output() { cout<<"\n\r输出党员信息:"<<endl; Adult::output(); cout<<parties<<endl; } }; // 程序入口 void main() { // 测试党员类(按继承关系可以一起测试居民类、成人类) Party party; party.input(); party.output(); }

4、 设计一个时钟类,能够记录时、分、秒,重载它的++运算符,每执行一次++运算,加时1秒,但要使计时过程能够自动进位。

/** * C++时钟 * 作者:hellostory * 日期:2010-11-23 */ #include<iostream> #include<cmath> using namespace std; /* * 时钟类 */ class Clock { private: int Hour, Minute, Second; public: Clock(int h=0, int m=0, int s=0); void ShowTime(); Clock& operator ++(); Clock operator ++(int); }; /* * 时钟类构造函数 */ Clock::Clock(int h,int m, int s) { if(h>=0 && h<=24 && m>=0 && m<=60 && s>=0 && s<=60) { Hour = h; Minute =m; Second= s; } else cout<<"输入的时间格式错误!"<<endl; } /* * 显示时间 */ void Clock::ShowTime() { cout<<Hour<<":"<<Minute<<":"<<Second<<endl; } /* * 时间递增一秒(重载前缀++运算符) */ Clock& Clock::operator ++() { Second++; if (Second >= 60) { Second = Second - 60; Minute++; if (Minute >= 60) { Minute = Minute - 60; Hour++; Hour = Hour % 24; } } return *this; } /* * 时间递增一秒(重载后缀++运算符) */ Clock Clock::operator ++(int) { Clock old = *this; ++(*this); return old; } /* * 主函数 */ void main() { Clock myClock(23,59,59); cout<<"初始化显示时间为:\t\t"; myClock.ShowTime(); cout<<"执行myClock++后的时间为:\t"; //先执行ShowTime(),输出myClock=23:59:59, //再执行myClock++,此时myClock=00:00:00 (myClock++).ShowTime(); cout<<"执行++myClock后的时间为:\t"; //先执行++myClock,此时myClock=00:00:01 //再执行ShowTime(),输出myClock=00:00:01 (++myClock).ShowTime(); }

5、 简化的职工档案管理程序。其中把职工的档案数据和对这些数据的设置、修改、删除、添加等操作组成一个程序模块。程序通过这个模块一类的公有部分对档案数据进行处理,实现了面向对象程序设计的“封装”功能。

说明:需要在同目录下新建一个文件sort.txt

/** * 职工档案数据管理系统 * 作者:hellostory * 日期:2010-11-23 */ #include <iostream> #include <fstream> #include <string.h> #include <conio.h> using namespace std; // 职工类Staff class Staff { public: char Id[20]; //工号 char name[20]; //姓名 char sex[10]; //性别 char dept[20]; //部门 Staff * Next; //指向下一个职工节点 // 录入一个职工的档案数据 void Input() { cout<<"\t请输入新职工的档案数据:"<<endl; cout<<"\t工号:"; cin>>Id; cout<<"\t姓名:"; cin>>name; cout<<"\t性别:"; cin>>sex; cout<<"\t部门:"; cin>>dept; } // 从文件(sort.txt)输入流中读取一行数据赋值给Staff对象 void ReadFile(istream & in) { in>>Id>>name>>sex>>dept; } // 显示该职工的档案数据 void Show() { cout<<"\t工号\t姓名\t性别\t部门"<<endl; cout<<"\t"<<Id<<"\t"<<name<<"\t"<<sex<<"\t"<<dept<<endl; } }; // 职工档案数据管理类Staffmassage class Staffmassage { private: Staff * Head,* End; ifstream in; ofstream out; // 根据职工姓名查找并返回职工档案数据(返回前一个节点) Staff *FindItem(char * name) { for(Staff *p=Head; p->Next != End; p=p->Next) { if(!strcmp(p->Next->name,name)) return p; } return NULL; } // 根据职工工号查找并返回职工档案数据(返回前一个节点) Staff *FindID(char * Id) { for(Staff * p=Head; p->Next!=End; p=p->Next) { if(!strcmp(p->Next->Id,Id)) return p; } return NULL; } public: Staffmassage(); ~Staffmassage(); void ShowMenu(); void Find(); void Save(); void ModifyItem(); void RemoveItem(); void Swap(Staff *,Staff *); void Sort(); int ListCount(); // 显示全部职工的档案数据 void Display() { for(Staff *p=Head->Next; p!=End; p=p->Next){ p->Show(); } cout<<"\t输入任意字符继续..."; getch(); } // 增加职工档案数据 void AddItem() { End->Input(); End->Next = new Staff; End = End->Next; cout<<"\t添加成功!"<<endl; cout<<"\t输入任意字符继续..."; getch(); } }; // 构造函数 Staffmassage::Staffmassage() { Head = new Staff; Head->Next = new Staff; End = Head->Next; in.open("sort.txt"); if(!in) cout<<"系统无任何职工档案数据!请先录入职工档案数据!"<<endl; else { while(!in.eof()) { End->ReadFile(in); if(End->name[0]=='\0') break; End->Next = new Staff; End = End->Next; } in.close(); cout<<"读取职工档案数据成功!"<<endl; } } // 析构函数 Staffmassage::~Staffmassage() { // 将职工档案数据保存在文本文件中 Save(); // 删除存放职工档案数据的链表 for(Staff * temp;Head->Next!=End;) { temp=Head->Next; Head->Next=temp->Next; delete temp; } delete Head,End; } // 显示系统菜单 void Staffmassage::ShowMenu() { cout<<"\t ┏━━━━━━━━━━━━━━┓ "<<endl; cout<<"\t┏━━━━━━┫ 职 工 管 理 系 统 ┣━━━━━━┓"<<endl; cout<<"\t┃ ┗━━━━━━━━━━━━━━┛ ┃"<<endl; cout<<"\t┃ 1.增加职工档案数据 4.查找职工档案数据 ┃"<<endl; cout<<"\t┃ 2.显示职工档案数据 5.删除职工档案数据 ┃"<<endl; cout<<"\t┃ 3.排序统计档案数据 6.修改职工档案数据 ┃"<<endl; cout<<"\t┃ 0.安全退出系统 ┃"<<endl; cout<<"\t┗━━━━━━━━━━━━━━━━━━━━━━━━━━━━┛"<<endl; cout<<"\n\t请选择:"; } // 查找并显示职工档案数据 void Staffmassage::Find() { char name[20] ,Id[10]; int x; Staff * p=NULL; cout<<"\n\t━━━━━━━━━━━━━━━━━\n"; cout<<"\t 1.按职工的姓名查找 2.按职工学号查找"; cout<<"\n\t━━━━━━━━━━━━━━━━━\n\t请选择:"; cin>>x; switch(x) { case 1: { cout<<"\t请输入要查找的职工的姓名:"; cin>>name; if(p=FindItem(name)) { p->Next->Show(); cout<<"\t输入任意字符继续..."; getch(); } else { cout<<"\t没有找到该姓名的职工!\n"<<endl; cout<<"\t输入任意字符继续..."; getch(); } } break; case 2: { cout<<"\t请输入要查找的职工的学号:"; cin>>Id; if(p=FindID(Id)) { p->Next->Show(); cout<<"\t输入任意字符继续..."; getch(); } else { cout<<"\t没有找到该工号的职工!\n"<<endl; cout<<"\t输入任意字符继续..."; getch(); } } break; } } // 修改职工档案数据 void Staffmassage::ModifyItem() { char name[20]; Staff * p=NULL; cout<<"\t请输入要修改的职工姓名:"; cin>>name; if(p=FindItem(name)) { cout<<"\t已找到职工的档案数据,请输入新的档案数据!"<<endl; p->Next->Input(); cout<<"\t修改成功!"<<endl; cout<<"\t输入任意字符继续..."; getch(); } else { cout<<"\t对不起,没有找到该职工档案数据!"<<endl; cout<<"\t输入任意字符继续..."; getch(); } } // 根据职工姓名删除对应的档案数据 void Staffmassage::RemoveItem() { char name[20]; Staff * p=NULL,*temp=NULL; cout<<"\t请输入要删除的职工的姓名:"<<endl;cin>>name; if(p=FindItem(name)) { // 先使被删除职工的前一个节点Next指向其下一个节点 temp=p->Next; p->Next=temp->Next; // 再删除该职工节点数据 delete temp; cout<<"\t删除成功!"<<endl; cout<<"\t输入任意字符继续..."; getch(); } else { cout<<"\t对不起,没有找到该职工档案数据!"<<endl; cout<<"\t输入任意字符继续..."; getch(); } } // 交换两个职工的档案数据 void Staffmassage::Swap(Staff *p1, Staff *p2) { Staff *temp=new Staff; strcpy(temp->Id,p1->Id); strcpy(temp->name,p1->name); strcpy(temp->sex,p1->sex); strcpy(temp->dept,p1->dept); strcpy(p1->Id,p2->Id); strcpy(p1->name,p2->name); strcpy(p1->sex,p2->sex); strcpy(p1->dept,p2->dept); strcpy(p2->name,temp->name); strcpy(p2->Id,temp->Id); strcpy(p2->sex,temp->sex); strcpy(p2->dept,temp->dept); } // 统计当前链表的记录总数,返回一个整数 int Staffmassage::ListCount() { if(!Head) { return 0; } int n=0; for(Staff * p=Head->Next;p!=End;p=p->Next) { n++; } return n; } // 对当前链表进行排序(采用选择排序算法) void Staffmassage::Sort() { cout <<"\t正在排序(按工号从小到大)..."<<endl; Staff *p=NULL,*p1=NULL,*k=NULL; int n=Staffmassage::ListCount(); if(n<2) return; for(p=Head->Next; p!=End; p=p->Next) { for(k=p->Next;k!=End;k=k->Next) { if(p->Id < k->Id) { Staffmassage::Swap(p,k); } } } cout <<"\t排序完成!"<<endl; getch(); return; } // 保存职工档案数据到文本文件"sort.txt" void Staffmassage::Save() { out.open("sort.txt"); for(Staff *p=Head->Next;p!=End;p=p->Next) { out<<p->Id<<"\t"<<p->name<<"\t"<<p->sex<<"\t"<<p->dept<<'\n'; } out.close(); } // 主函数(程序入口) int main() { cout<<"欢迎进入【职工档案数据管理系统】!"<<endl; Staffmassage Grade; //创建职工档案管理对象 cout<<"按任意键开始……"; getch(); int x; bool quit = false; while(!quit) { system("cls"); //清除DOS屏幕 Grade.ShowMenu(); //显示系统菜单 cin>>x; switch(x) { case 0:quit=true;break; case 1:Grade.AddItem();break; case 2:Grade.Display();break; case 3:Grade.Sort();break; case 4:Grade.Find();break; case 5:Grade.RemoveItem();break; case 6:Grade.ModifyItem();break; } } return 0; }

【程序1】 题目: 有1、2、3、4个数字,能组成多少个互不相同且无重复数字的三位数?都是多少? 【程序2】 题目:企业发放的奖金根据利润提成。利润(I)低于或等于10万元时,奖金可提10%;利润高    于10万元,低于20万元时,低于10万元的部分按10%提成,高于10万元的部分,可可提    成7.5%;20万到40万之间时,高于20万元的部分,可提成5%;40万到60万之间时高于    40万元的部分,可提成3%;60万到100万之间时,高于60万元的部分,可提成1.5%,高于    100万元时,超过100万元的部分按1%提成,从键盘输入当月利润I,求应发放奖金总数? 【程序3】 题目:一个整数,它加上100后是一个完全平方数,再加上168又是一个完全平方数,请问该数是多少? 【程序4】 题目:输入某年某月某日,判断这一天是这一年的第几天? 【程序5】 题目:输入三个整数x,y,z,请把这三个数由小到大输出。 【程序6】 题目:用*号输出字母C的图案。 【程序8】 题目:输出9*9口诀。 【程序9】 题目:要求输出国际象棋棋盘。 【程序10】 题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月    后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少? 【程序11】 题目:判断101-200之间有多少个素数,并输出所有素数。 【程序12】 题目:打印出所有的“水仙花数”,所谓“水仙花数”是指一个三位数,其各位数字立方等于该数    本身。例如:153是一个“水仙花数”,因为153=1的三次方+5的三次方+3的三次方。 【程序13】 题目:将一个正整数分解质因数。例如:输入90,打印出90=2*3*3*5。 【程序14】 题目:利用条件运算符的嵌套来完成此题:学习成绩>=90分的同学用A表示,60-89分之间的用B表示,    60分以下的用C表示。 【程序15】 题目:输入两个正整数mn,求其最大公约数最小公倍数。 【程序16】 题目:输入一行字符,分别统计出其中英文字母、空格、数字其它字符的个数。 【程序17】 题目:求s=a+aa+aaa+aaaa+aa...a的值,其中a是一个数字。例如2+22+222+2222+22222(此时    共有5个数相加),几个数相加有键盘控制。 【程序18】 题目:一个数如果恰好等于它的因子之,这个数就称为“完数”。例如6=1+2+3.编程    找出1000以内的所有完数。 【程序19】 题目:一球从100米高度自由落下,每次落地后反跳回原高度的一半;再落下,求它在    第10次落地时,共经过多少米?第10次反弹多高? 【程序20】 题目:请输入星期几的第一个字母来判断一下是星期几,如果第一个字母一样,则继续    判断第二个字母。 【程序21】 题目:求100之内的素数    【程序22】 题目:对10个数进行排序 【程序23】 题目:求一个3*3矩阵对角线元素之 【程序24】 题目:有一个已经排好序的数组。现输入一个数,要求按原来的规律将它插入数组中。 【程序25】 题目:将一个数组逆序输出。 【程序26】 题目:取一个整数a从右端开始的4~7位。 【程序27】 题目:打印出杨辉三角形(要求打印出10行)    【程序28】 题目:输入3个数a,b,c,按大小顺序输出。    【程序29】 题目:输入数组,最大的与第一个元素交换,最小的与最后一个元素交换,输出数组。 【程序30】 题目:有n个人围成一圈,顺序排号。从第一个人开始报数(从1到3报数),凡报到3的人退出    圈子,问最后留下的是原来第几号的那位。 【程序31】 题目:编写一个函数,输入n为偶数时,调用函数求1/2+1/4+...+1/n,当输入n为奇数时,调用函数    1/1+1/3+...+1/n(利用指针函数) 【程序32】 题目:海滩上有一堆桃子,五只猴子来分。第一只猴子把这堆桃子凭据分为五份,多了一个,这只    猴子把多的一个扔入海中,拿走了一份。第二只猴子把剩下的桃子又平均分成五份,又多了    一个,它同样把多的一个扔入海中,拿走了一份,第三、第四、第五只猴子都是这样做的,    问海滩上原来最少有多少个桃子? 【程序33】 题目:求0—7所能组成的奇数个数。 【程序34】 题目:一个偶数总能表示为两个素数之
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值