欢迎来到得力文库 - 分享文档赚钱的网站! | 帮助中心 好文档才是您的得力助手!
得力文库 - 分享文档赚钱的网站
全部分类
  • 研究报告>
  • 管理文献>
  • 标准材料>
  • 技术资料>
  • 教育专区>
  • 应用文书>
  • 生活休闲>
  • 考试试题>
  • pptx模板>
  • 工商注册>
  • 期刊短文>
  • 图片设计>
  • ImageVerifierCode 换一换

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

    • 资源ID:33727614       资源大小:766.50KB        全文页数:201页
    • 资源格式: DOC        下载积分:15金币
    快捷下载 游客一键下载
    会员登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录   QQ登录  
    二维码
    微信扫一扫登录
    下载资源需要15金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

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

    如有侵权,请联系网站删除,仅供学习与交流#C语言程序设计课后习题答案(第四版)谭浩强【精品文档】第 201 页第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 <stdio.h>int main ( ) printf ("*nn"); printf(" Very Good!nn"); printf ("*n"); return 0;1-6#include <stdio.h>int main()int a,b,c,max; printf("please input a,b,c:n"); scanf("%d,%d,%d",&a,&b,&c); max=a; if (max<b) max=b; if (max<c) 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数据的表现形式及其运算393.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 <stdio.h>#include <math.h>int main()float p,r,n; r=0.1; n=10; p=pow(1+r,n); printf("p=%fn",p); return 0;3-2-1#include <stdio.h>#include <math.h>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次 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 <stdio.h>#include <math.h>int main()double 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次 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-3#include <stdio.h>#include <math.h>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次 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方案得到的本息和 printf("p5=%10.2fn",p5); / 输出按第5方案得到的本息和 return 0;3-3.#include <stdio.h>#include <math.h>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 <stdio.h>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 <stdio.h>int main()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 <stdio.h>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); return 0;3-7#include <stdio.h>int main ()float h,r,l,s,sq,vq,vz; float pi=3.141526; printf("请输入圆半径r,圆柱高h"); scanf("%f,%f",&r,&h); /要求输入圆半径r和圆柱高h l=2*pi*r; /计算圆周长l s=r*r*pi; /计算圆面积s sq=4*pi*r*r; /计算圆球表面积sq vq=3.0/4.0*pi*r*r*r; /计算圆球体积vq vz=pi*r*r*h; /计算圆柱体积vz printf("圆周长为: l=%6.2fn",l); printf("圆面积为: s=%6.2fn",s); printf("圆球表面积为: sq=%6.2fn",sq); printf("圆球体积为: v=%6.2fn",vq); printf("圆柱体积为: vz=%6.2fn",vz); return 0;3-8-1#include <stdio.h>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 <stdio.h>int main() char c1,c2; /定义字符型变量 int i1,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 <stdio.h>int main() char c1,c2; /定义为字符型 int i1,i2; /定义为整型 printf("请输入两个整数i1,i2:"); scanf("%d,%d",&i1,&i2); c1=i1; /将整数赋值给字符变量 c2=i2; printf("按字符输出结果:n"); printf("%c,%cn",c1,c2); printf("按整数输出结果:n"); printf("%d,%dn",c1,c2); return 0;3-8#include <stdio.h>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.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 <stdio.h>int main() int a,b,c; printf("请输入三个整数:"); scanf("%d,%d,%d",&a,&b,&c); if (a<b) if (b<c) printf("max=%dn",c); else printf("max=%dn",b); else if (a<c) printf("max=%dn",c); else printf("max=%dn",a); return 0;4-4-2#include <stdio.h>int main() int a,b,c,temp,max; printf("请输入三个整数:"); scanf("%d,%d,%d",&a,&b,&c); temp=(a>b)?a:b; /*将a和b中的大者存入temp中*/ max=(temp>c)?temp:c; /*将a和b中的大者和c比较,取最大者*/ printf("三个整数的最大数是%dn",max); return 0;4-5-2#include <stdio.h>#include <math.h>#define M 1000int main() int i,k; printf("请输入一个小于%d的整数i:",M); scanf("%d",&i); while (i>M) printf("输入的数不符合要求,请重新输入一个小于%d的整数i:",M); scanf("%d",&i); k=sqrt(i); printf("%d的平方根的整数部分是:%dn",i,k); return 0;4-5#include <stdio.h>#include <math.h>#define M 1000int main() int i,k; printf("请输入一个小于%d的整数i:",M); scanf("%d",&i); if (i>M) printf("输入的数不符合要求,请重新输入一个小于%d的整数i:",M); scanf("%d",&i); k=sqrt(i); printf("%d的平方根的整数部分是:%dn",i,k); return 0;4-6.#include <stdio.h>int main() int x,y; printf("输入x:"); scanf("%d",&x); if(x<1) /* x<1 */ y=x; printf("x=%3d, y=x=%dn" ,x,y); else if(x<10) /* 1=<x<10 */ y=2*x-1; printf("x=%d, y=2*x-1=%dn",x,y);else /* x>=10 */ y=3*x-11; printf("x=%d, y=3*x-11=%dn",x,y); return 0;4-7-1#include <stdio.h>int main() int x,y; printf("enter x:"); scanf("%d",&x); y=-1; if(x!=0) if(x>0) y=1; else y=0; printf("x=%d,y=%dn",x,y); return 0;4-7-2#include <stdio.h>int main() int x,y; printf("please enter x:"); scanf("%d",&x); y=0; if(x>=0) if(x>0) y=1; else y=-1; printf("x=%d,y=%dn",x,y); return 0;4-8#include <stdio.h>int main() float score; char grade; printf("请输入学生成绩:"); scanf("%f",&score); while (score>100|score<0)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);return 0;4-9#include <stdio.h>#include <math.h>int main() int num,indiv,ten,hundred,thousand,ten_thousand,place; /分别代表个位,十位,百位,千位,万位和位数 printf("请输入一个整数(0-99999):"); scanf("%d",&num); if (num>9999) place=5; else if (num>999) place=4; else if (num>99) place=3; else if (num>9) place=2; else place=1; printf("位数:%dn",place); printf("每位数字为:"); 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*10); switch(place) case 5:printf("%d,%d,%d,%d,%d",ten_thousand,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反序数字为:"); printf("%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 <stdio.h>int main() int i; double bonus,bon1,bon2,bon4,bon6,bon10; bon1=100000*0.1; bon2=bon1+100000*0.075; bon4=bon2+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; else bonus=bon10+(i-1000000)*0.01; printf("奖金是: %10.2fn",bonus); return 0;4-10-2#include <stdio.h>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; if (branch>10) 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.01; printf("奖金是 %10.2fn",bonus); return 0;4-11#include <stdio.h>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 (a>b) t=a;a=b;b=t; if (a>c) t=a;a=c;c=t; if (a>d) t=a;a=d;d=t; if (b>c) t=b;b=c;c=t; if (b>d) t=b;b=d;d=t; if (c>d) t=c;c=d;d=t; printf("排序结果如下: n"); printf("%d %d %d %d n" ,a,b,c,d); return 0;4-12#include <stdio.h>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)+(y-y3)*(y-y3); if (d1>1 && d2>1 && d3>1 && d4>1) 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循环程序举例131习题1405-2#include <stdio.h>#include <math.h> / 程序中用到数学函数fabs,应包含头文件math.nint 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; / sign代表符号,下一项的符号和上一项符号相反 term=sign/n; / 求出下一项的值term count+; / count累加1 pi=pi*4; / 多项式的和pi乘以4,才是的近似值 printf("pi=%10.8fn",pi); / 输出的近似值 printf("count=%dn",count); / 输出循环次数 return 0;5-3#include <stdio.h>int main() int p,r,n,m,temp; printf("请输入两个正整数n,m:"); scanf("%d,%d,",&n,&m); if (n<m) temp=n; n=m; m=temp; p=n*m; while(m!=0) r=n%m; n=m; m=r; printf("它们的最大公约数为:%dn",n); printf("它们的最小公约数为:%dn",p/n); return 0;5-4#include <stdio.h>int main() char c; int letters=0,space=0,digit=0,other=0; printf("请输入一行字符:n"); while(c=getchar()!='n') if (c>='a' && c<='z' | c>='A' && c<='Z') letters+; else if (c=' ') space+; else if (c>='0' && c<='9') digit+; else other+; printf("字母数:%dn空格数:%dn数字数:%dn其它字符数:%dn",letters,space,digit,other); return 0;5-5#include <stdio.h>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 <stdio.h>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#include <stdio.h>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 <stdio.h>int main() int i,j,k,n; printf("parcissus numbers are "); for (n=100;n<1000;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);

    注意事项

    本文(#《C语言程序设计》课后习题答案(第四版)谭浩强.doc)为本站会员(1595****071)主动上传,得力文库 - 分享文档赚钱的网站仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知得力文库 - 分享文档赚钱的网站(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于得利文库 - 版权申诉 - 用户使用规则 - 积分规则 - 联系我们

    本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知得利文库网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

    工信部备案号:黑ICP备15003705号-8 |  经营许可证:黑B2-20190332号 |   黑公网安备:91230400333293403D

    © 2020-2023 www.deliwenku.com 得利文库. All Rights Reserved 黑龙江转换宝科技有限公司 

    黑龙江省互联网违法和不良信息举报
    举报电话:0468-3380021 邮箱:hgswwxb@163.com  

    收起
    展开