收藏 分销(赏)

《c++程序设计》谭浩强课后习题答案.doc

上传人:xrp****65 文档编号:5913095 上传时间:2024-11-23 格式:DOC 页数:131 大小:441KB
下载 相关 举报
《c++程序设计》谭浩强课后习题答案.doc_第1页
第1页 / 共131页
《c++程序设计》谭浩强课后习题答案.doc_第2页
第2页 / 共131页
《c++程序设计》谭浩强课后习题答案.doc_第3页
第3页 / 共131页
《c++程序设计》谭浩强课后习题答案.doc_第4页
第4页 / 共131页
《c++程序设计》谭浩强课后习题答案.doc_第5页
第5页 / 共131页
点击查看更多>>
资源描述

1、第一章1.5题#include using namespace std;int main() coutThisis; coutaC+; coutprogram.; return 0;1.6题#include using namespace std;int main() int a,b,c; a=10; b=23; c=a+b; couta+b=; coutc; coutendl; return 0;1.7七题#include using namespace std;int main() int a,b,c; int f(int x,int y,int z); cinabc; c=f(a,b,c

2、); coutcendl; return 0;int f(int x,int y,int z) int m; if (xy) m=x; else m=y; if (zm) m=z; return(m); 1.8题#include using namespace std;int main() int a,b,c; cinab; c=a+b; couta+b=a+bendl; return 0;1.9题#include using namespace std;int main() int a,b,c; int add(int x,int y); cinab; c=add(a,b); couta+b

3、=cendl; return 0;int add(int x,int y)int z; z=x+y; return(z);2.3题#include using namespace std;int main() char c1=a,c2=b,c3=c,c4=101,c5=116; coutc1c2c3n; couttbc4tc5n; return 0;2.4题#include using namespace std;int main() char c1=C,c2=+,c3=+; coutI say: c1c2c3; coutttHe says: C+ is very interesting! n

4、; return 0;2.7题#include using namespace std;int main()int i,j,m,n; i=8; j=10; m=+i+j+; n=(+i)+(+j)+m; coutitjtmtnendl; return 0;2.8题#include using namespace std;int main()char c1=C, c2=h, c3=i, c4=n, c5=a; c1+=4; c2+=4; c3+=4; c4+=4; c5+=4; coutpassword is:c1c2c3c4c5endl; return 0;3.2题#include #incl

5、ude using namespace std;int main ( )float h,r,l,s,sq,vq,vz; const float pi=3.1415926; coutrh; l=2*pi*r; s=r*r*pi; sq=4*pi*r*r; vq=3.0/4.0*pi*r*r*r; vz=pi*r*r*h; coutsetiosflags(ios:fixed)setiosflags(ios:right) setprecision(2); coutl= setw(10)lendl; couts= setw(10)sendl; coutsq=setw(10)sqendl; coutvq

6、=setw(10)vqendl; coutvz=setw(10)vzendl; return 0; 3.3题#include using namespace std;int main ()float c,f; coutf; c=(5.0/9.0)*(f-32); /注意5和9要用实型表示,否则5/9值为0 cout摄氏温度为:cendl; return 0;3.4题#include using namespace std;int main ( )char c1,c2; cout请输入两个字符c1,c2:; c1=getchar(); /将输入的第一个字符赋给c1 c2=getchar(); /

7、将输入的第二个字符赋给c2 cout用putchar函数输出结果为:; putchar(c1); putchar(c2); coutendl; cout用cout语句输出结果为:; coutc1c2endl; return 0;3.4题另一解#include using namespace std;int main ( )char c1,c2; cout请输入两个字符c1,c2:; c1=getchar(); /将输入的第一个字符赋给c1 c2=getchar(); /将输入的第二个字符赋给c2 cout用putchar函数输出结果为:; putchar(c1); putchar(44); p

8、utchar(c2); coutendl; cout用cout语句输出结果为:; coutc1,c2endl; return 0;3.5题#include using namespace std;int main ( )char c1,c2; int i1,i2; /定义为整型 couti1i2; c1=i1; c2=i2; cout按字符输出结果为:c1 , c2endl; return 0;3.8题#include using namespace std;int main ( ) int a=3,b=4,c=5,x,y; coutc & b=c)endl; cout(a|b+c & b-c

9、)endl; coutb) & !c|1)endl; cout(!(x=a) & (y=b) & 0)endl; cout(!(a+b)+c-1 & b+c/2)endl; return 0; 3.9题include using namespace std;int main ( ) int a,b,c; coutabc; if(ab) if(bc) coutmax=c; else coutmax=b; else if (ac) coutmax=c; else coutmax=a; coutendl;return 0; 3.9题另一解#include using namespace std;in

10、t main ( ) int a,b,c,temp,max ; coutabc; temp=(ab)?a:b; /* 将a和b中的大者存入temp中 */ max=(tempc)?temp:c; /* 将a和b中的大者与c比较,最大者存入max */ coutmax=maxendl; return 0; 3.10题#include using namespace std;int main ( ) int x,y; coutx; if (x1) y=x; coutx=x, y=x=y; else if (x10) / 1x10 y=2*x-1; coutx=x, y=2*x-1=y; else

11、/ x10 y=3*x-11; coutx=x, y=3*x-11=y; coutendl;return 0;3.11题#include using namespace std;int main () float score; char grade; coutscore; while (score100|score0) coutscore; switch(int(score/10) case 10: case 9: grade=A;break; case 8: grade=B;break; case 7: grade=C;break; case 6: grade=D;break; defaul

12、t:grade=E; coutscore is score, grade is gradeendl; return 0;3.12题#include using namespace std;int main ()long int num; int indiv,ten,hundred,thousand,ten_thousand,place; /*分别代表个位,十位,百位,千位,万位和位数 */ coutnum; if (num9999) place=5; else if (num999) place=4; else if (num99) place=3; else if (num9) place=

13、2; else place=1; coutplace=placeendl; /计算各位数字 ten_thousand=num/10000; thousand=(int)(num-ten_thousand*10000)/1000; hundred=(int)(num-ten_thousand*10000-thousand*1000)/100; ten=(int)(num-ten_thousand*10000-thousand*1000-hundred*100)/10; indiv=(int)(num-ten_thousand*10000-thousand*1000-hundred*100-ten

14、*10); coutoriginal order:; switch(place) case 5:coutten_thousand,thousand,hundred,ten,indiven dl; coutreverse order:; coutindivtenhundredthousandten_thousandendl; break; case 4:coutthousand,hundred,ten,indivendl; coutreverse order:; coutindivtenhundredthousandendl; break; case 3:couthundred,ten,indi

15、vendl; coutreverse order:; coutindivtenhundredendl; break; case 2:coutten,indivendl; coutreverse order:; coutindivtenendl; break; case 1:coutindivendl; coutreverse order:; coutindivendl; break; return 0; 3.13题#include using namespace std;int main () long i; /i为利润 float bonus,bon1,bon2,bon4,bon6,bon1

16、0; bon1=100000*0.1; /利润为10万元时的奖金 bon2=bon1+100000*0.075; /利润为20万元时的奖金 bon4=bon2+100000*0.05; /利润为40万元时的奖金 bon6=bon4+100000*0.03; /利润为60万元时的奖金 bon10=bon6+400000*0.015; /利润为100万元时的奖金 couti; if (i=100000) bonus=i*0.1; /利润在10万元以内按10%提成奖金 else if (i=200000) bonus=bon1+(i-100000)*0.075; /利润在10万元至20万时的奖金 e

17、lse if (i=400000) bonus=bon2+(i-200000)*0.05; /利润在20万元至40万时的奖金 else if (i=600000) bonus=bon4+(i-400000)*0.03; /利润在40万元至60万时的奖金 else if (i=1000000) bonus=bon6+(i-600000)*0.015; /利润在60万元至100万时的奖金 else bonus=bon10+(i-1000000)*0.01; /利润在100万元以上时的奖金 coutbonus=bonusendl; return 0; 3.13题另一解#include using n

18、amespace std;int main ()long i; float bonus,bon1,bon2,bon4,bon6,bon10; int c; bon1=100000*0.1; bon2=bon1+100000*0.075; bon4=bon2+200000*0.05; bon6=bon4+200000*0.03; bon10=bon6+400000*0.015; couti; c=i/100000; if (c10) c=10; switch(c) case 0: bonus=i*0.1; break; case 1: bonus=bon1+(i-100000)*0.075; b

19、reak; case 2: case 3: bonus=bon2+(i-200000)*0.05;break; case 4: case 5: bonus=bon4+(i-400000)*0.03;break; case 6: case 7: case 8: case 9: bonus=bon6+(i-600000)*0.015; break; case 10: bonus=bon10+(i-1000000)*0.01; coutbonus=bonusendl; return 0;3.14题#include using namespace std;int main ()int t,a,b,c,

20、d; coutabcd; couta=a, b=b, c=c,d=db) t=a;a=b;b=t; if (ac) t=a; a=c; c=t; if (ad) t=a; a=d; d=t; if (bc) t=b; b=c; c=t; if (bd) t=b; b=d; d=t; if (cd) t=c; c=d; d=t; coutthe sorted sequence:endl; couta, b, c, dendl; return 0; 3.15题#include using namespace std;int main ()int p,r,n,m,temp; coutnm; if (

21、nm) temp=n; n=m; m=temp; /把大数放在n中, 小数放在m中 p=n*m; /先将n和m的乘积保存在p中, 以便求最小公倍数时用 while (m!=0) /求n和m的最大公约数 r=n%m; n=m; m=r; coutHCF=nendl; coutLCD=p/nendl; / p是原来两个整数的乘积 return 0; 3.16题#include using namespace std;int main ()char c; int letters=0,space=0,digit=0,other=0; coutenter one line:=a & c=A & c=0

22、& c=9) digit+; else other+; coutletter:letters, space:space, digit:digit, other:otherendl; return 0; 3.17题#include using namespace std;int main ()int a,n,i=1,sn=0,tn=0; coutan; while (i=n) tn=tn+a; /赋值后的tn为i个a组成数的值 sn=sn+tn; /赋值后的sn为多项式前i项之和 a=a*10; +i; couta+aa+aaa+.=snendl; return 0; 3.18题#include

23、 using namespace std;int main ()float s=0,t=1; int n; for (n=1;n=20;n+) t=t*n; / 求n! s=s+t; / 将各项累加 cout1!+2!+.+20!=sendl; return 0; 3.19题#include using namespace std;int main ()int i,j,k,n; coutnarcissus numbers are:endl; for (n=100;n1000;n+) i=n/100; j=n/10-i*10; k=n%10; if (n = i*i*i + j*j*j + k*

24、k*k) coutn ; coutendl;return 0; 3.20题#include using namespace std; int main() const int m=1000; / 定义寻找范围 int k1,k2,k3,k4,k5,k6,k7,k8,k9,k10; int i,a,n,s; for (a=2;a=m;a+) / a是21000之间的整数,检查它是否为完数 n=0; / n用来累计a的因子的个数 s=a; / s用来存放尚未求出的因子之和,开始时等于a for (i=1;ia;i+) / 检查i是否为a的因子 if (a%i=0) / 如果i是a的因子 n+; /

25、 n加1,表示新找到一个因子 s=s-i; / s减去已找到的因子,s的新值是尚未求出的因子 之和 switch(n) / 将找到的因子赋给k1,.,k10 case 1: k1=i; break; / 找出的笫1个因子赋给k1 case 2: k2=i; break; / 找出的笫2个因子赋给k2 case 3: k3=i; break; / 找出的笫3个因子赋给k3 case 4: k4=i; break; / 找出的笫4个因子赋给k4 case 5: k5=i; break; / 找出的笫5个因子赋给k5 case 6: k6=i; break; / 找出的笫6个因子赋给k6 case

26、7: k7=i; break; / 找出的笫7个因子赋给k7 case 8: k8=i; break; / 找出的笫8个因子赋给k8 case 9: k9=i; break; / 找出的笫9个因子赋给k9 case 10: k10=i; break; / 找出的笫10个因子赋给k10 if (s=0) / s=0表示全部因子都已找到了 couta is a 完数endl; cout1) coutk1,1表示a至少有2个因子 if (n2) cout,2表示至少有3个因子,故应再输出一个因子 if (n3) cout,3表示至少有4个因子,故应再输出一个因子 if (n4) cout,5) co

27、ut,6) cout,7)cout,8)cout,9)cout,k10; coutendlendl; return 0; 3.20题另一解#include using namespace std; int main() int m,s,i; for (m=2;m1000;m+) s=0; for (i=1;im;i+) if (m%i)=0) s=s+i; if(s=m) coutm is a完数endl; coutits factors are:; for (i=1;im;i+) if (m%i=0) couti ; coutendl; return 0; 3.20题另一解#include

28、using namespace std;int main() int k11; int i,a,n,s; for (a=2;a=1000;a+) n=0; s=a; for (i=1;ia;i+) if (a%i)=0) n+; s=s-i; kn=i; / 将找到的因子赋给k1k10 if (s=0) couta is a 完数endl; coutits factors are:; for (i=1;in;i+) coutki ; coutknendl; return 0; 3.21题#include using namespace std;int main() int i,t,n=20;

29、double a=2,b=1,s=0; for (i=1;i=n;i+) s=s+a/b; t=a; a=a+b; / 将前一项分子与分母之和作为下一项的分子 b=t; / 将前一项的分子作为下一项的分母 coutsum=sendl; return 0; 3.22题#include using namespace std;int main() int day,x1,x2; day=9; x2=1; while(day0) x1=(x2+1)*2; / 第1天的桃子数是第2天桃子数加1后的2倍 x2=x1; day-; couttotal=x1endl; return 0; 3.23题#incl

30、ude #include using namespace std;int main() float a,x0,x1; couta; / 输入a的值 x0=a/2; x1=(x0+a/x0)/2; do x0=x1; x1=(x0+a/x0)/2; while(fabs(x0-x1)=1e-5); coutThe square root of a is x1endl; return 0; 3.24题#include using namespace std;int main() int i,k; for (i=0;i=3;i+) / 输出上面4行*号 for (k=0;k=2*i;k+) cout

31、*; / 输出*号 coutendl; /输出完一行*号后换行 for (i=0;i=2;i+) / 输出下面3行*号 for (k=0;k=4-2*i;k+) cout*; / 输出*号 coutendl; / 输出完一行*号后换行 return 0; 3.25题#include using namespace std;int main() char i,j,k; /* i是a的对手;j是b的对手;k是c的对手*/ for (i=X;i=Z;i+) for (j=X;j=Z;j+) if (i!=j) for (k=X;k=Z;k+) if (i!=k & j!=k) if (i!=X & k!=X & k!=Z) coutA-i B-j C-kendl; retu

展开阅读全文
部分上传会员的收益排行 01、路***(¥15400+),02、曲****(¥15300+),
03、wei****016(¥13200+),04、大***流(¥12600+),
05、Fis****915(¥4200+),06、h****i(¥4100+),
07、Q**(¥3400+),08、自******点(¥2400+),
09、h*****x(¥1400+),10、c****e(¥1100+),
11、be*****ha(¥800+),12、13********8(¥800+)。
相似文档                                   自信AI助手自信AI助手
搜索标签

当前位置:首页 > 应用文书 > 其他

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        获赠5币

©2010-2024 宁波自信网络信息技术有限公司  版权所有

客服电话:4008-655-100  投诉/维权电话:4009-655-100

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :gzh.png    weibo.png    LOFTER.png 

客服