《C语言程序设计》课后习题答案()谭浩强.doc

上传人:韩长文 文档编号:6297762 上传时间:2020-10-22 格式:DOC 页数:62 大小:13.17KB
返回 下载 相关 举报
《C语言程序设计》课后习题答案()谭浩强.doc_第1页
第1页 / 共62页
《C语言程序设计》课后习题答案()谭浩强.doc_第2页
第2页 / 共62页
《C语言程序设计》课后习题答案()谭浩强.doc_第3页
第3页 / 共62页
《C语言程序设计》课后习题答案()谭浩强.doc_第4页
第4页 / 共62页
《C语言程序设计》课后习题答案()谭浩强.doc_第5页
第5页 / 共62页
点击查看更多>>
资源描述

《《C语言程序设计》课后习题答案()谭浩强.doc》由会员分享,可在线阅读,更多相关《《C语言程序设计》课后习题答案()谭浩强.doc(62页珍藏版)》请在三一文库上搜索。

1、第1章程序设计和C语言11.1什么是计算机程序11.2什么是计算机语言11.3C语言的发展及其特点31.4最简单的C语言程序51.4.1最简单的C语言程序举例61.4.2C语言程序的结构101.5运行C程序的步骤与方法121.6程序设计的任务141-5 #include int main ( ) printf (*nn);printf( Very Good!nn);printf (*n);return 0;1-6#include int main()int a,b,c,max;printf(please input a,b,c:n);scanf(%d,%d,%d,&a,&b,&c);max=a

2、;if (maxb)max=b;if (maxc)max=c;printf(The largest number is %dn,max);return 0;第2章算法程序的灵魂162.1什么是算法162.2简单的算法举例172.3算法的特性212.4怎样表示一个算法222.4.1用自然语言表示算法222.4.2用流程图表示算法222.4.3三种基本结构和改进的流程图262.4.4用NS流程图表示算法282.4.5用伪代码表示算法312.4.6用计算机语言表示算法322.5结构化程序设计方法34习题36第章最简单的C程序设计顺序程序设计373.1顺序程序设计举例373.2数据的表现形式及其运算3

3、93.2.1常量和变量393.2.2数据类型423.2.3整型数据443.2.4字符型数据473.2.5浮点型数据493.2.6怎样确定常量的类型513.2.7运算符和表达式523.3C语句573.3.1C语句的作用和分类573.3.2最基本的语句赋值语句593.4数据的输入输出653.4.1输入输出举例653.4.2有关数据输入输出的概念673.4.3用printf函数输出数据683.4.4用scanf函数输入数据753.4.5字符数据的输入输出78习题823-1 #include #include int main()float p,r,n;r=0.1;n=10;p=pow(1+r,n);

4、printf(p=%fn,p);return 0;3-2-1#include #include int main()float r5,r3,r2,r1,r0,p,p1,p2,p3,p4,p5;p=1000;r5=0.0585;r3=0.054;r2=0.0468;r1=0.0414;r0=0.0072;p1=p*(1+r5)*5); / 一次存5年期p2=p*(1+2*r2)*(1+3*r3); / 先存2年期,到期后将本息再存3年期p3=p*(1+3*r3)*(1+2*r2); / 先存3年期,到期后将本息再存2年期p4=p*pow(1+r1,5); / 存1年期,到期后将本息存再存1年期,

5、连续存5次 p5=p*pow(1+r0/4,4*5); / 存活期存款。活期利息每一季度结算一次printf(p1=%fn,p1); / 输出按第1方案得到的本息和printf(p2=%fn,p2); / 输出按第2方案得到的本息和printf(p3=%fn,p3); / 输出按第3方案得到的本息和printf(p4=%fn,p4); / 输出按第4方案得到的本息和printf(p5=%fn,p5); / 输出按第5方案得到的本息和return 0;3-2-2#include #include int main()double r5,r3,r2,r1,r0,p,p1,p2,p3,p4,p5;p

6、=1000;r5=0.0585;r3=0.054;r2=0.0468;r1=0.0414;r0=0.0072;p1=p*(1+r5)*5); / 一次存5年期p2=p*(1+2*r2)*(1+3*r3); / 先存2年期,到期后将本息再存3年期p3=p*(1+3*r3)*(1+2*r2); / 先存3年期,到期后将本息再存2年期p4=p*pow(1+r1,5); / 存1年期,到期后将本息存再存1年期,连续存5次 p5=p*pow(1+r0/4,4*5); / 存活期存款。活期利息每一季度结算一次printf(p1=%fn,p1); / 输出按第1方案得到的本息和printf(p2=%fn,p

7、2); / 输出按第2方案得到的本息和printf(p3=%fn,p3); / 输出按第3方案得到的本息和printf(p4=%fn,p4); / 输出按第4方案得到的本息和printf(p5=%fn,p5); / 输出按第5方案得到的本息和return 0;3-2-3#include #include int main()float r5,r3,r2,r1,r0,p,p1,p2,p3,p4,p5;p=1000;r5=0.0585;r3=0.054;r2=0.0468;r1=0.0414;r0=0.0072;p1=p*(1+r5)*5); / 一次存5年期p2=p*(1+2*r2)*(1+3*

8、r3); / 先存2年期,到期后将本息再存3年期p3=p*(1+3*r3)*(1+2*r2); / 先存3年期,到期后将本息再存2年期p4=p*pow(1+r1,5); / 存1年期,到期后将本息存再存1年期,连续存5次 p5=p*pow(1+r0/4,4*5); / 存活期存款。活期利息每一季度结算一次printf(p1=%10.2fn,p1); / 输出按第1方案得到的本息和printf(p2=%10.2fn,p2); / 输出按第2方案得到的本息和printf(p3=%10.2fn,p3); / 输出按第3方案得到的本息和printf(p4=%10.2fn,p4); / 输出按第4方案得

9、到的本息和printf(p5=%10.2fn,p5); / 输出按第5方案得到的本息和return 0;3-3.#include #include int main()float d=300000,p=6000,r=0.01,m;m=log10(p/(p-d*r)/log10(1+r);printf(m=%6.2fn,m);return 0;3-4#include int main()int c1,c2;c1=197;c2=198;printf(c1=%c,c2=%cn,c1,c2);printf(c1=%d,c2=%dn,c1,c2);return 0;3-5#include int mai

10、n()int a,b;float x,y;char c1,c2;scanf(a=%d b=%d,&a,&b);scanf(%f %e,&x,&y);scanf(%c%c,&c1,&c2);printf(a=%d,b=%d,x=%f,y=%f,c1=%c,c2=%cn,a,b,x,y,c1,c2);return 0;3-6#include int main()char c1=C,c2=h,c3=i,c4=n,c5=a;c1=c1+4;c2=c2+4;c3=c3+4;c4=c4+4;c5=c5+4;printf(passwor is %c%c%c%c%cn,c1,c2,c3,c4,c5);retu

11、rn 0;3-7#include int main ()float h,r,l,s,sq,vq,vz;float pi=3.141526;printf(请输入圆半径r,圆柱高h);scanf(%f,%f,&r,&h); /要求输入圆半径r和圆柱高hl=2*pi*r; /计算圆周长ls=r*r*pi; /计算圆面积ssq=4*pi*r*r; /计算圆球表面积sqvq=3.0/4.0*pi*r*r*r; /计算圆球体积vqvz=pi*r*r*h; /计算圆柱体积vzprintf(圆周长为: l=%6.2fn,l);printf(圆面积为: s=%6.2fn,s);printf(圆球表面积为: sq

12、=%6.2fn,sq);printf(圆球体积为: v=%6.2fn,vq);printf(圆柱体积为: vz=%6.2fn,vz);return 0;3-8-1#include int main()int c1,c2; /整型定义printf(请输入两个整数c1,c2:);scanf(%d,%d,&c1,&c2);printf(按字符输出结果:n);printf(%c,%cn,c1,c2);printf(按ASCII码输出结果为:n);printf(%d,%dn,c1,c2);return 0;3-8-2#include int main()char c1,c2; /定义字符型变量int i

13、1,i2; /定义整型变量printf(请输入两个字符c1,c2:);scanf(%c,%c,&c1,&c2);i1=c1; /赋值给整型变量i2=c2;printf(按字符输出结果:n);printf(%c,%cn,i1,i2);printf(按整数输出结果:n);printf(%d,%dn,c1,c2);return 0;3-8-3#include int main()char c1,c2; /定义为字符型int i1,i2; /定义为整型printf(请输入两个整数i1,i2:);scanf(%d,%d,&i1,&i2);c1=i1; /将整数赋值给字符变量c2=i2;printf(按字

14、符输出结果:n);printf(%c,%cn,c1,c2);printf(按整数输出结果:n);printf(%d,%dn,c1,c2);return 0;3-8#include int main()char c1,c2;printf(请输入两个字符c1,c2:);c1=getchar();c2=getchar();printf(用putchar语句输出结果为:);putchar(c1);putchar(c2);printf(n);printf(用printf语句输出结果为:);printf(%c %cn,c1,c2);return 0;第4章选择结构程序设计854.1选择结构和条件判断854

15、.2用if语句实现选择结构874.2.1用if语句处理选择结构举例874.2.2if语句的一般形式 894.3关系运算符和关系表达式914.3.1关系运算符及其优先次序914.3.2关系表达式924.4逻辑运算符和逻辑表达式924.4.1逻辑运算符及其优先次序934.4.2逻辑表达式944.4.3逻辑型变量964.5条件运算符和条件表达式974.6选择结构的嵌套994.7用switch语句实现多分支选择结构1024.8选择结构程序综合举例105习题1114-4-1#include int main()int a,b,c;printf(请输入三个整数:);scanf(%d,%d,%d,&a,&b

16、,&c);if (ab)if (bc)printf(max=%dn,c);elseprintf(max=%dn,b);else if (ac)printf(max=%dn,c);elseprintf(max=%dn,a);return 0;4-4-2#include int main() int a,b,c,temp,max;printf(请输入三个整数:);scanf(%d,%d,%d,&a,&b,&c);temp=(ab)?a:b; /*将a和b中的大者存入temp中*/max=(tempc)?temp:c; /*将a和b中的大者与c比较,取最大者*/ printf(三个整数的最大数是%d

17、n,max);return 0;4-5-2#include #include #define M 1000int main()int i,k;printf(请输入一个小于%d的整数i:,M);scanf(%d,&i);while (iM)printf(输入的数不符合要求,请重新输入一个小于%d的整数i:,M);scanf(%d,&i);k=sqrt(i);printf(%d的平方根的整数部分是:%dn,i,k);return 0;4-5#include #include #define M 1000int main()int i,k;printf(请输入一个小于%d的整数i:,M);scanf

18、(%d,&i);if (iM)printf(输入的数不符合要求,请重新输入一个小于%d的整数i:,M);scanf(%d,&i);k=sqrt(i);printf(%d的平方根的整数部分是:%dn,i,k);return 0;4-6.#include int main() int x,y;printf(输入x:);scanf(%d,&x);if(x1) /* x1 */ y=x;printf(x=%3d, y=x=%dn ,x,y);else if(x10) /* 1=x=10 */ y=3*x-11;printf(x=%d, y=3*x-11=%dn,x,y);return 0;4-7-1#

19、include int main()int x,y;printf(enter x:);scanf(%d,&x);y=-1;if(x!=0)if(x0)y=1;elsey=0;printf(x=%d,y=%dn,x,y);return 0;4-7-2#include int main()int x,y;printf(please enter x:);scanf(%d,&x);y=0;if(x=0)if(x0) y=1;else y=-1;printf(x=%d,y=%dn,x,y);return 0;4-8#include int main() float score;char grade;pr

20、intf(请输入学生成绩:);scanf(%f,&score);while (score100|score0)printf(n 输入有误,请重输);scanf(%f,&score);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;case 5:case 4:case 3:case 2:case 1:case 0: grade=E;printf(成绩是 %5.1f,相应的等级是%cn ,score,grade);

21、return 0;4-9#include #include int main()int num,indiv,ten,hundred,thousand,ten_thousand,place;位,万位和位数printf(请输入一个整数(0-99999):);scanf(%d,&num);if (num9999)place=5;else if (num999)place=4;else if (num99) /分别代表个位,十位,百位,千place=3;else if (num9)place=2;else place=1;printf(位数:%dn,place);printf(每位数字为:);ten_

22、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*10);switch(place)case 5:printf(%d,%d,%d,%d,%d,ten_tho

23、usand,thousand,hundred,ten,indiv);printf(n反序数字为:);printf(%d%d%d%d%dn,indiv,ten,hundred,thousand,ten_thousand);break;case 4:printf(%d,%d,%d,%d,thousand,hundred,ten,indiv);printf(n反序数字为:);printf(%d%d%d%dn,indiv,ten,hundred,thousand);break;case 3:printf(%d,%d,%d,hundred,ten,indiv);printf(n反序数字为:);print

24、f(%d%d%dn,indiv,ten,hundred);break;case 2:printf(%d,%d,ten,indiv);printf(n反序数字为:);printf(%d%dn,indiv,ten);break;case 1:printf(%d,indiv);printf(n反序数字为:);printf(%dn,indiv);break;return 0;4-10-1#include int main()int i;double bonus,bon1,bon2,bon4,bon6,bon10;bon1=100000*0.1;bon2=bon1+100000*0.075;bon4=b

25、on2+100000*0.05;bon6=bon4+100000*0.03;bon10=bon6+400000*0.015;printf(请输入利润i:);scanf(%d,&i);if (i=100000)bonus=i*0.1;else if (i=200000)bonus=bon1+(i-100000)*0.075;else if (i=400000)bonus=bon2+(i-200000)*0.05;else if (i=600000)bonus=bon4+(i-400000)*0.03;else if (i=1000000)bonus=bon6+(i-600000)*0.015;e

26、lsebonus=bon10+(i-1000000)*0.01;printf(奖金是: %10.2fn,bonus);return 0;4-10-2#include int main()int i;double bonus,bon1,bon2,bon4,bon6,bon10;int branch;bon1=100000*0.1;bon2=bon1+100000*0.075;bon4=bon2+200000*0.05;bon6=bon4+200000*0.03;bon10=bon6+400000*0.015;printf(请输入利润i:);scanf(%d,&i);branch=i/100000

27、;if (branch10) branch=10;switch(branch) case 0:bonus=i*0.1;break;case 1:bonus=bon1+(i-100000)*0.075;break;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.

28、01;printf(奖金是 %10.2fn,bonus);return 0;4-11#include int main()int t,a,b,c,d;printf(请输入四个数:);scanf(%d,%d,%d,%d,&a,&b,&c,&d);printf(a=%d,b=%d,c=%d,d=%dn,a,b,c,d);if (ab) 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;printf(排序结果如下: n);pri

29、ntf(%d %d %d %d n ,a,b,c,d);return 0;4-12#include int main()int h=10;float x1=2,y1=2,x2=-2,y2=2,x3=-2,y3=-2,x4=2,y4=-2,x,y,d1,d2,d3,d4;printf(请输入一个点(x,y):);scanf(%f,%f,&x,&y);d1=(x-x4)*(x-x4)+(y-y4)*(y-y4); /*求该点到各中心点距离*/d2=(x-x1)*(x-x1)+(y-y1)*(y-y1);d3=(x-x2)*(x-x2)+(y-y2)*(y-y2);d4=(x-x3)*(x-x3)+

30、(y-y3)*(y-y3);if (d11 & d21 & d31 & d41) h=0; /*判断该点是否在塔外*/printf(该点高度为 %dn,h);return 0;第5章循环结构程序设计1145.1为什么需要循环控制1145.2用while语句实现循环1155.3用dowhile语句实现循环1175.4用for 语句实现循环1205.5循环的嵌套1245.6几种循环的比较1255.7改变循环执行的状态1255.7.1用break语句提前终止循环1265.7.2用continue语句提前结束本次循环1275.7.3break语句和continue语句的区别1285.8循环程序举例13

31、1习题1405-2#include #include / 程序中用到数学函数fabs,应包含头文件math.n int main()int sign=1,count=0; / sign用来表示数值的符号,count用来统计循环次数 double pi=0.0,n=1.0,term=1.0; / pi开始代表多项式的值,最后代表的值, n代表分母,term代表当前项的值while(fabs(term)=1e-8) / 检查当前项term的绝对值是否大于或等于10的(-6)次方pi=pi+term; / 把当前项term累加到pi中n=n+2; / n+2是下一项的分母sign=-sign; /

32、sign代表符号,下一项的符号与上一项符号相反 term=sign/n; / 求出下一项的值termcount+; / count累加1pi=pi*4; / 多项式的和pi乘以4,才是的近似值 printf(pi=%10.8fn,pi); / 输出的近似值printf(count=%dn,count); / 输出循环次数return 0;5-3#include int main()int p,r,n,m,temp;printf(请输入两个正整数n,m:);scanf(%d,%d,&n,&m);if (nm)temp=n;n=m;m=temp;p=n*m;while(m!=0)r=n%m;n=m

33、;m=r;printf(它们的最大公约数为:%dn,n);printf(它们的最小公约数为:%dn,p/n);return 0;5-4#include int main()char c;int letters=0,space=0,digit=0,other=0;printf(请输入一行字符:n);while(c=getchar()!=n)if (c=a & c=A & c=0 & c=9)digit+;elseother+;printf(字母数:%dn空格数:%dn数字数:%dn其它字符数:%dn,letters,space,digit,other); return 0;5-5#include

34、 int main()int a,n,i=1,sn=0,tn=0;printf(a,n=:);scanf(%d,%d,&a,&n);while (i=n)tn=tn+a; /*赋值后的tn为i个 a组成数的值*/sn=sn+tn; /*赋值后的sn为多项式前i项之和*/a=a*10;+i;printf(a+aa+aaa+.=%dn,sn);return 0;5-6#include int main()double s=0,t=1;int n;for (n=1;n=20;n+)t=t*n;s=s+t;printf(1!+2!+.+20!=%22.15en,s);return 0;5-7#incl

35、ude int main()int n1=100,n2=50,n3=10;double k,s1=0,s2=0,s3=0;for (k=1;k=n1;k+) /*计算1到100的和*/s1=s1+k;for (k=1;k=n2;k+) /*计算1到50各数的平方和*/s2=s2+k*k;for (k=1;k=n3;k+) /*计算1到10的各倒数和*/s3=s3+1/k;printf(sum=%15.6fn,s1+s2+s3);return 0;5-8#include int main()int i,j,k,n;printf(parcissus numbers are );for (n=100

36、;n1000;n+)i=n/100;j=n/10-i*10;k=n%10;if (n=i*i*i + j*j*j + k*k*k)printf(%d ,n);printf(n);return 0;5-9-1#define M 1000 /*定义寻找范围*/#include int main()int k1,k2,k3,k4,k5,k6,k7,k8,k9,k10;int i,a,n,s;for (a=2;a=M;a+) /* a是2-1000之间的整数,检查它是否完数 */n=0; /* n用来累计a的因子的个数 */s=a; /* s用来存放尚未求出的因子之和,开始时等于a */ for (i

37、=1;ia;i+) /* 检查i是否a的因子 */if (a%i=0) /* 如果i是a的因子 */n+; /* n加1,表示新找到一个因子 */s=s-i; /* s减去已找到的因子,s的新值是尚未求出的因子之和 */ switch(n) /* 将找到的因子赋给k1.k9,或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 7:k7=i; break; /* 找出的笫7个因子赋给k7 */case 8:k8=i; break; /* 找出的笫8个因子赋给k8 */case 9:k9=i; break; /*找出

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 科普知识


经营许可证编号:宁ICP备18001539号-1