习题答案
当前位置:学习资源下载>课后习题答案
第一章C++基础知识习题
1.1 判断下列标识符的合法性。
sin book 5arry _name Example2.1 main $1 class_cpp a3 x*y my name
答:合法的:sin book _name main class_cpp a3
非法的:5arry Example2.1 $1 x*y my name 1.2假定有下列变量: int a=3,b=5,c=0;
float x=2.5,y=8.2,z=1.4;
char ch1= a ,ch2= 5 ,ch3= 0 ,ch4;
求下列表达式的值,以及运算后表达式所涉及的各变量的值。
x+(int)y%a x=z*b++,b=b*x,b++ ch4=ch3-ch2+ch1 int(y/z)+(int)y/(int)z !(a>b)&&c&&(x*=y)&&b++ ch3||(b+=a*c)||c++ z=(a<<2)/(b>>1)
答:x+(int)y%a值为:4.5
x=z*b++,b=b*x,b++值为:42,x为7,b为43 ch4=ch3-ch2+ch1值为: \\ int(y/z)+(int)y/(int)z值为:13
!(a>b)&&c&&(x*=y)&&b++值为:0,b为5 注:只要出现一个false右边的不再做。 ch3||(b+=a*c)||c++值为:1,c为0 注:只要出现一个true,右边不再做。 z=(a<<2)/(b>>1)值为:6
1.3判断下列哪些是常量,哪些是变量。
"China" const int n=10; int m=5; 'a' char ch='a' int array[5]={1,2,3,4,5}; char s[]="Hello";
答:"China" 文字常量 const int n=10;常变量 int m=5;变量 'a' 文字常量 char ch='a'变量
int array[5]={1,2,3,4,5};变量 char s[]="Hello";变量
1.4将下列算式或叙述用C++表达式描述。 (1)
(2) (x+y)/((x-y)*ay)
(3)位于原点为圆心,a, b为半径的圆环中的点坐标。 (4) 。
习题答案
(5) 并且字符ch不为'\0'。
答: pi/2+sqrt(asin(x)*asin(x)+c*c) (x+y)/((x-y)*pow(a,y))
((x*x+y*y)>=a*a)&&((x*x+y*y)<=b*b) (a!=b)&&(a!=c)&&(b!=c) (k<=20)&&(ch!='\0')
1.6设有语句: int a, b; float x,y;
char ch1,ch2,ch3;
cin>>a>>b>>x>>y>>ch1; ch2=cin.get(); cin>>ch3;
若从键盘输入: 3 2 1.8 7 a b c
执行后各变量取值如何?注意abc三字符两两间有空格。
答:a是3,b是2,x是1.8,y是7,ch1是 a ,ch2是空格,ch3是 b 。
1.7设有语句: int a,b,c,d;
cin>>oct>>a>>b>>hex>>c>>dec>>d; 若从键盘输入: 23 23 23 23
执行后各变量的值用十进制表示各是多少?
答:a:19,b:19,c:35,d:23 1.8对于习题1.7,若执行:
cout<<a<<′\t′<<hex<<b<<′\t′<<oct<<c<<endl; 显示结果是什么?
答:19 0x13 043 当前位置:学习资源下载>课后习题答案
第二章基本控制结构程序设计习题
一.基本概念与基础知识自测题
2.1程序阅读题 2.1.1设有说明: int a=3, b=100;
下面的循环语句执行(1)次,执行后a、b的值分别为(2)、(3)。 while(b/a>5){
if(b-a>25) a++;
习题答案
elseb/=a;
}
解答:
(1)14 (2)17 (3)100
2.1.2设有说明: int x,y,n,k;
下面程序段的功能是备选答案中的 (1) ,当n=10,x=10打印结果是 (2) 。 cin>>x>>n; k=0; do{
x/=2; k++; }while(k<n); y=1+x; k=0; do{
y=y*y; k++; }while(k<n); cout<<y<<endl; 备选答案:
A. B. C. D. 解答:
第一个循环使x成为:;y成为:;第二个循环使y成为:; (1)B
考虑整除,当x连除4次2以后即为0,所以:为0 (2)1
2.1.3请看如下程序段: if(num==1) cout<<”Alpha”; else if(num==2) cout<<”Bata”;
习题答案
else if(num==3) cout<<”Gamma”;
else cout<<”Delta”;
当num的值分别为1、2、3时,上面程序段的输出分别为(1)、(2)、(3)。
解答:
检查条件语句与字符串输出概念: (1)Alpha (2)Bata (3)Gamma
2.1.4执行下面程序段后,m和k的值分别为、 int m,k;
for(k=1,m=0;k<=50;k++){
if(m>=10) break; if(m%2==0){
m+=5; continue; } m-=3; }
(2)8
二.编程与综合练习题
2.2有一个函数:
编写程序,输入x,输出y。
解:
#include <iostream> using namespace std; int main(){
double x,y;
习题答案
cout<<"输入x="; cin>>x;
if(x<1) y=x;
else if(x<10) y=2*x-1; else y=3*x-11; cout<<"y="<<y<<endl; return 0; }
2.3设计程序将输入的百分制成绩转换为五分制输出,90分以上为5分,80 89分为4分,70 79分为3分,60 69分为2分,60分以下为1分。
解:10分一档用10进行整除获得,转换用开关语句实行。 #include <iostream> using namespace std; int main(){
int mark,result; //mark是百分制成绩,result是5分制 cout<<"请输入百分制成绩:"<<endl; cin>>mark; if(mark<0) {
cout<<"缺考!"<<endl; return 0; }
switch (mark/10){ case 9: case 10: result=5;
cout<<"输出五分制成绩:"<<result<<endl; break; case 8:
result=4;
cout<<"输出五分制成绩:"<<result<<endl; break; case 7:
result=3;
cout<<"输出五分制成绩:"<<result<<endl; break; case 6:
result=2;
cout<<"输出五分制成绩:"<<result<<endl; break;
case 5:case 4:case 3:case 2:case 1:case 0: result=1;
cout<<"输出五分制成绩:"<<result<<endl; break; default:
习题答案
cout<<"输入错误!"<<endl; }
return 0; }
2.4编程计算个人所得税。个人所得税率表如下:月收入1200元起征,超过起征点500元以内部分税率5%,超过500元到2,000元部分税率10%,超过2,000元到5,000元部分税率15%,超过5,000元到20,000元部分税率20%,超过20,000元到40,000元部分税率25%,超过40,000元到60,000元部分税率30%,超过60,000元到80,000元部分税率35%,超过80,000元到100,000元部分税率40%,超过100,000元部分税率45%。
解:应该从最高税率段开始计算,分段叠加。先算两万元以上各段,每两万为一档,采用switch语句,注意没有使用break语句。后面各低收入段,用if语句,也没有使用else,这两种方法是对应的。第二要注意计算的入口处,收入减去该段的下限,进行计算,以后各段都是完整的段,计算十分简单。 #include <iostream> using namespace std; int main(){
double income,tax=0; int k;
cout<<"请输入个人月收入:"<<endl; cin>>income;
if(income<=1200){
cout<<"免征个人所得税"<<endl; return 0; }
else income-=1200; if(income>20000){
k=income/20000; switch(k){
default: tax+=(income-100000)*0.45;income=100000; case 4: tax+=(income-80000)*0.40;income=80000; case 3: tax+=(income-60000)*0.35;income=60000; case 2: tax+=(income-40000)*0.30;income=40000; case 1: tax+=(income-20000)*0.25;income=20000; } }
if(income>5000){
tax+=(income-5000)*0.20; income=5000; }
if(income>2000){
tax+=(income-2000)*0.15; income=2000; }
习题答案
if(income>500){
tax+=(income-500)*0.10; income=500; }
tax+=income*0.05;
cout<<"应征所得税:"<<tax<<endl; return 0; }
2.5编程打印如下图形: * * * * * * * * * * * * * * * * * * * * * * * * *
解:难点在三角形左边的空格的控制,嵌套一个循环语句完成此任务。 #include <iostream> using namespace std; int main(){ int i,j;
for (i=1;i<=4;i++){
for(j=4-i;j>0;j--) cout<<" ";//三角形每行前部的空格 for(j=1;j<=2*i-1;j++) cout<<" *"; cout<<endl; }
for(i=1;i<=3;i++) cout<<" * * *\n"; return 0; }
2.6编程输出下列图形,中间一行英文字母由输入得到。
A B B B C C C C C
D D D D D D D C C C C C B B B A
解:分上三角和下三角两部分分别处理左边的空格。 #include <iostream> using namespace std; int main(){ char in; int i,j;
习题答案
do{
cout<<"输入一个字母:"; cin>>in;
if((in>=97)&&(in<=122)) in-=32;//小写改大写 }while((in<65)||(in>90)); int line=in-'A';
for (i=0;i<=line;i++){//上三角
for(j=line-i;j>0;j--) cout<<" ";//前方空格 for(j=1;j<=2*i+1;j++) cout<<' '<<char(i+'A'); cout<<endl; }
for (i=line;i>0;i--){//下三角(少一行) for(j=0;j<=line-i;j++) cout<<" ";
for(j=1;j<=2*i-1;j++) cout<<' '<<char(i-1+'A'); cout<<endl; }
return 0; }
2.7输入n,求1!+2!+3!+…+n!
解:通常求和作为外循环,阶乘作为内循环。这里考虑到:n!=n*(n-1)!,利用递推法运算速度大大提高,同时两者可合并为一个循环。本程序考虑了输入的健壮性。 #include <iostream> #include <cstdlib> using namespace std; int main(){
int n,i,jch=1;
double result=0; //result是结果 cout<<"请输入正整数n:"<<endl; cin>>n; if(n<1){
cout<<"输入错误!"<<endl; return 1; }
result=1;
for(i=2;i<=n;i++){
jch*=i; //jch是i的阶乘,注意n!=n*(n-1)!这样可少一层循环 result+=jch; }
cout<<result<<endl; return 0; }
2.8猴子吃桃问题:猴子摘下若干个桃子,第一天吃了桃子的一半多一个,以后每天吃了前
习题答案
一天剩下的一半多一个,到第十天吃以前发现只剩下一个桃子,问猴子共摘了几个桃子。 解:采用递推法。从最后一天逆推到第一天,9次循环。 #include <iostream> using namespace std; const int day=10; int main(){
int i,x=1;//最后一天只有一个
for(i=1;i<day;i++) x=(x+1)*2; //从一天前推到九天前 cout<<"开始共有桃子"<<x<<"个。\n"; return 0; }
2.9从键盘输入一组非0整数,以输入0标志结束,求这组整数的平均值,并统计其中正数和负数的个数。
解:将这组整数放在整型数组中,一边输入一边求和及统计正数和负数的个数,平均数由和除以整数数量取得。 #include <fstream> #include <iostream> using namespace std; int main(){
int stem[256],sum=0,pnum=0,nnum=0,i=0;
cout<<"从键盘输入一组非0整数,以输入0标志结束:"<<endl; cin>>stem[i];
while(stem[i]!=0){
sum+=stem[i];//求和
if(stem[i]>0) pnum++;//正数数量 else nnum++;//负数数量 i++;
cin>>stem[i]; }
if(!i) cout<<"0个数"<<endl; else {
cout<<"平均值="<<(double)sum/(pnum+nnum)<<endl;//平均值习惯不用整数 cout<<"正数个数="<<pnum<<endl; cout<<"负数个数="<<nnum<<endl; }
return 0; }
2.10编程找出1 500之中满足除以3余2,除以5余3,除以7余2的整数。 解:中国古代数学问题(韩信点兵),采用穷举法。注意三个条件同时成立用&&。 #include <iostream> using namespace std; int main(){
习题答案
int i;
for(i=1;i<=500;i++)
if((i%3==2)&&(i%5==3)&&(i%7==2)) cout<<i<<endl; return 0; }
2.11编程求1000之内的所有完全数。所谓完全数指的是一个数恰好等于它的所有因子和。例如6=1+2+3,就是一个完全数。
解:采用穷举法。两重循环,外层是从1到999依次处理,内层是求该数的所有因子的和,并判断是否等于该数。 #include <iostream> using namespace std; int main(){
int i,a,sum_yz; //sum_yz是a的因子和 for(a=1;a<1000;a++){ sum_yz=0;
for(i=1;i<a;i++) if (a%i==0) sum_yz+=i;
//求因子运算未改变循环控制变量a的值,否则要用另一个变量b来代替a来参加
运算
if (a==sum_yz) cout<<a<<endl; }
return 0; }
2.12将100元换成用10元、5元和1元的组合,共有多少种组合方法。 解:采用穷举法。考虑10元最多10张,5元最多20张,余下是1元。 #include <iostream> using namespace std; int main(){
int i,j,k,count=0;
for(i=0;i<=10;i++)//i是10元张数,j是5元张数,k是1元张数 for(j=0;j<=20;j++){
k=100-10*i-5*j; if(k>=0){
cout<<i<<'\t'<<j<<'\t'<<k<<endl; count++; } }
cout<<count<<endl; return 0; }
2.13利用反正切展开计算 的近似值,要求误差10-5,公式如下:
习题答案
令x=1,可计算出 /4的近似值。
解:采用递推法。初看每一项的递推通式不易写出,但每一项全看作奇数项,而偶数项全为零,则很容易写出:第1项为x,第3项为第1项乘以x的平方除以项序号3乘以-1,其余类推。同时和的误差小于最后一项的绝对值。 #include<iostream> #include<cmath> using namespace std; const double e=1e-5; int main(){
double x,a,sum; int i=3;
cout<<"请输入正切值:"<<endl; cin>>x; a=x; sum=x; do{
a*=x*x*(-1); sum+=a/i; i+=2;
}while(fabs(a/i)>e);
cout<<"arctg("<<x<<")="<<sum<<endl; return 0; }
2.14用迭代法求方程x2+10cosx=0的根,误差限为10-5。迭代公式如下:
解:迭代法也是用循环语句实现,数学上迭代法可能收敛,也可能发散,解答中加了最大迭代次数的限制。 #include<iostream> #include<cmath> using namespace std; const double e=1e-5; int main(){
double x0,x1; int n=0;
cout<<"输入初始近似值:"<<endl; cin>>x1; do{
x0=x1;
x1=(x0*x0-10*(x0*sin(x0)+cos(x0)))/(2*x0-10*sin(x0));
//x0是上次算出的结果,x1用作保存新算出的结果 n++;
} while ((fabs(x1-x0) >e)&&(n<=1e5)); if(n>1e5)
习题答案
cout<<"超出迭代1e5次\n";
else cout<<"方程x*x+10*cos(x)=0的一个根为:"<<x1<<endl; cout<<"方程误差为:"<<x1*x1+10*cos(x1)<<endl; return 0; }
2.15两队选手每队5人进行一对一的比赛,甲队为A、B、C、D、E,乙队为J、K、L、M、N,经过抽签决定比赛配对名单。规定A不和J比赛,M不和D及E比赛。列出所有可能的比赛名单。
解:这是一个组合问题,使用穷举法。共有5个位置,设甲队5名队员位置不变,乙队改变队员位置,进行配对。注意第1个位置可在5个队员中任选一个,以后的位置必须扣除已选过的队员。并扣除不能配对的情况,即得所有可能的比赛名单。 #include<iostream> using namespace std; int main(){
char st1[5]={'A','B','C','D','E'},st2[5]={'J','K','L','M','N'}; int i=0,j,k,l,m,n;
for(j=0;j<5;j++){//0号位
if(j==0) continue;//A选手不与选手J比赛,即st1[0]不与st2[0]比赛 for(k=0;k<5;k++){//1号位
if(k==j) continue;//剔除乙队占据0号位的选手 for(l=0;l<5;l++){//2号位
if(l==j||l==k) continue;//剔除乙队占据0、1号位的选手 for(m=0;m<5;m++){//3号位
if(m==j||m==k||m==l) continue;//剔除乙队占据0、1、2号位的选手
if(m==3) continue;//st1[3]不与st2[3]比赛,即D不与M比赛
for(n=0;n<5;n++){//4号位
if(n==j||n==k||n==l||n==m) continue;
//剔除乙队占据0、1、2、3号位的选手
if(n==3) continue;//st1[4]不与st2[3]比赛,即E不与M比赛
cout<<st1[0]<<'-'<<st2[j]<<'\t'<<st1[1]<<'-'<<st2[k]<<'\t';
cout<<st1[2]<<'-'<<st2[l]<<'\t'<<st1[3]<<'-'<<st2[m]<<'\t';
cout<<st1[4]<<'-'<<st2[n]<<endl; i++; } } } } }
习题答案
cout<<i<<endl; return 0; }
2.16编程模拟选举过程。假定四位候选人:zhang、wang、li、zhao,代号分别为1、2、3、4。选举人直接键入候选人代号,1 4之外的整数视为弃权票,-1为终止标志。打印各位候选人的得票以及当选者(得票数超过选票总数一半)名单。
解:用5个元素的整型数组,分别放弃权票和各候选人的得票,然后用开关语句打印。 #include<iostream> #include<iomanip> using namespace std; int main(){
enum candidate{feipiao,zhang,wang,li,zhao}cand; int vote[5]={0},i,k=0,n; cin>>n;
while(n!=-1){ k++;
if(n>=1&&n<=4) vote[n]++; else vote[0]++; cin>>n; }
for(i=0;i<5;i++){
cand=(candidate)i; switch(cand){ case feipiao:
cout<<setw(10)<<"feipiao"<<'\t'<<vote[cand]<<endl;break; case zhang:cout<<setw(10)<<"zhang"<<'\t'<<vote[cand]; if(vote[cand]>k/2) cout<<" 当选"<<endl; else cout<<endl; break;
case wang:cout<<setw(10)<<"wang"<<'\t'<<vote[cand]; if(vote[cand]>k/2) cout<<" 当选"<<endl; else cout<<endl; break;
case li:cout<<setw(10)<<"li"<<'\t'<<vote[cand]; if(vote[cand]>k/2) cout<<" 当选"<<endl; else cout<<endl; break;
case zhao:cout<<setw(10)<<"zhao"<<'\t'<<vote[cand]; if(vote[cand]>k/2) cout<<" 当选"<<endl; else cout<<endl; break; } }
习题答案
return 0; }
2.17改造【例2.14】,将运行结果(Fibonacii数列的前20项)存入文件。 解:采用3步法。所谓3步法,是将书上的第1和第2步合并,格式如下: 首先建立或打开一个输出文件,并与磁盘文件联系:
ofstream ofile("myfile2_17.txt");
再按一定格式存入数据:ofile<<setw(15)<<fib0<<setw(15)<<fib1;等 然后关闭文件:ofile.close();
如要读出数据,则用输入文件打开,并与同一磁盘文件联系:
ifstream ifile("myfile2_17.txt");
再按同一格式读入数据:ifile>>i>>j>>k>>l;等,并输出 最后关闭文件:file.close(); #include<fstream> #include<iostream> #include<iomanip> using namespace std; const int m=20; int main(){
int fib0=0,fib1=1,fib2,i,j,k,l,n; char ch;
ofstream ofile("myfile2_17.txt");
ofile<<setw(15)<<fib0<<setw(15)<<fib1; for(n=3;n<=m;n++){ fib2=fib0+fib1;
ofile<<setw(15)<<fib2;
if(n%5==0) ofile<<endl; //控制每行5个数据 fib0=fib1; fib1=fib2; }
ofile.close();
cout<<"是否要将文件输出?Y或N"<<endl; cin>>ch;
if(ch=='y'||ch=='Y'){
ifstream ifile("myfile2_17.txt"); while(1){
ifile>>i>>j>>k>>l>>n;//由文件读入 if(ifile.eof()!=0) break;
cout<<setw(15)<<i<<setw(15)<<j<<setw(15)<<k
<<setw(15)<<l<<setw(15)<<n<<endl;//显示
} ifile.close(); }
return 0; }
习题答案
2.18改造【例2.19】,将运行结果(100以内素数)存入文件。 解:采用4步法。首先定义一个输出文件:ofstream ofile;
再打开该文件并与并与磁盘文件联系:ofile.open("myfile2_18.txt"); 按一定格式把数据存入文件。最后关闭文件。效果与3步法相同。 读文件同样可用3步法或4步法。 #include<fstream> #include<iostream> #include<iomanip> #include<cmath> using namespace std; const int n=100; int main(){
int a[n],i,j; char ch,b[256]; ofstream ofile; ifstream ifile;
for(i=0;i<n;i++) a[i]=1+i; //用数组保存整数1-100
a[0]=0; //1不是素数,置0 for(i=0;i<n;i++){
if(a[i]==0) continue; //该数已经置0,判断下一个数 for(j=i+1;j<n;j++) if(a[j]%a[i]==0) a[j]=0; //是a[i]倍数的元素置0; }
ofile.open("myfile2_18.txt"); int count=0;
ofile<<"1-"<<n<<"之间的素数:"<<endl;
for(i=0;i<n;i++) //输出所有素数 if(a[i]!=0){
ofile<<setw(6)<<a[i]; count++;
if(count%10==0) ofile<<endl; //每行10个数据 } ofile.close();
cout<<"是否要将文件输出?Y或N"<<endl; cin>>ch;
if(ch=='y'||ch=='Y'){
ifile.open("myfile2_18.txt"); i=0;
while(ifile.get(b[i])){//不可用>>,它不能读白字符, if(b[i]=='\n') break; i++; } b[i]='\0';
cout<<b<<endl;
习题答案
count=0; while(1){
ifile>>i;//由文件读入 cout<<setw(6)<<i;//屏幕显示 count++;
if(count%10==0) cout<<endl; //每行10个数
if(ifile.eof()!=0) break;//最后一个数据后面可能没有回车,直接为文件结束 }
ifile.close(); cout<<endl; }
return 0; }
2.19改造【例2.13】,文本由文本文件输入。
解:文本文件读入要用成员函数: ifile.get(),而不可用插入运算符<<,否则会丢失空白字符。 #include<fstream> #include<iostream> using namespace std; int main(){ char ch;
int nline=0,nword=0,nch=0; int isword=0;
ifstream ifile("ep2_19.cpp");
cout<<"读入ep2_19.cpp"<<endl; do{
ch=ifile.get();
if(ch=='\n') nline++; //遇换行符行数+1
if(ch!=' '&&ch!='\t'&&ch!='\n'&&ch!=EOF){ //读到非间隔符
if(!isword) nword++; //在单词的起始处给单词数+1
nch++; //字符数加+1
isword=1; }
else isword=0; //读到间隔符
}while(ch!=EOF); //读到文本结束符为止 ifile.close();
cout<<"行数:"<<nline<<endl; cout<<"单词数:"<<nword<<endl; cout<<"字符数:"<<nch<<endl; return 0;