c程序设计(第四版)谭浩强-课后答案(完整版).pdf(共201页).doc
精选优质文档-倾情为你奉上C 语言课后习题答案-第四版- 谭浩强(1-7)第一章#include <stdio.h>int main ( ) printf ("*nn"); printf(" Very Good!nn");printf ("*n"); return 0;#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;第 3 章#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;#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;#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;#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;#include <stdio.h> #include <math.h> int main()float d=,p=6000,r=0.01,m; m=log10(p/(p-d*r)/log10(1+r); printf("m=%6.2fn",m);return 0;#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;#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;#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;#include <stdio.h> int main ()float h,r,l,s,sq,vq,vz;float pi=3.; 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=%6.2fn",sq);printf("圆球体积为:v=%6.2fn",vq);printf("圆柱体积为:vz=%6.2fn",vz);return 0;#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;#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;#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;#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;第四章#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);elseprintf("max=%dn",b);else if (a<c)printf("max=%dn",c);elseprintf("max=%dn",a);return 0;#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; #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;#include <stdio.h> #include <math.h> #define M 1000 int 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;#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);elseif(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; #include <stdio.h> int main()int x,y;printf("enter x:"); scanf("%d",&x); y=-1;if(x!=0)if(x>0)y=1;elsey=0;printf("x=%d,y=%dn",x,y);return 0;#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;#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;#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;elseif (num>999)place=4;elseif (num>99)place=3;elseif (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; #include <stdio.h>int main()int i;double bonus,bon1,bon2,bon4,bon6,bon10; bon1=*0.1; bon2=bon1+*0.075; bon4=bon2+*0.05; bon6=bon4+*0.03; bon10=bon6+*0.015; printf("请输入利润 i:");scanf("%d",&i);if (i<=) bonus=i*0.1;else if (i<=) bonus=bon1+(i-)*0.075;else if (i<=) bonus=bon2+(i-)*0.05;else if (i<=) bonus=bon4+(i-)*0.03;else if (i<=)bonus=bon6+(i-)*0.015; elsebonus=bon10+(i-)*0.01; printf("奖金是: %10.2fn",bonus);return 0;#include <stdio.h> int main()int i;double bonus,bon1,bon2,bon4,bon6,bon10; int branch;bon1=*0.1;bon2=bon1+*0.075;bon4=bon2+*0.05;bon6=bon4+*0.03;bon10=bon6+*0.015; printf("请输入利润 i:"); scanf("%d",&i); branch=i/;if (branch>10) branch=10; switch(branch) case 0:bonus=i*0.1;break;case 1:bonus=bon1+(i-)*0.075;break;case 2:case 3: bonus=bon2+(i-)*0.05;break;case 4:case 5: bonus=bon4+(i-)*0.03;break; case 6:case 7: case 8:case 9: bonus=bon6+(i-)*0.015;break; case 10: bonus=bon10+(i-)*0.01;printf("奖金是 %10.2fn",bonus);return 0; #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%dn",a,b,c,d);return 0; #include <stdio.h> int main()inth=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;第五章#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;/ 求出下一项的值 termcount+;/ count 累加 1pi=pi*4;/ 多项式的和 pi 乘以 4,才是的近似值printf("pi=%10.8fn",pi);/ 输出的近似值printf("count=%dn",count);/ 输出循环次数return 0;#include <stdio.h>int main()intp,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;#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+;elseother+;printf("字母数:%dn 空格数:%dn 数字数:%dn 其它字符数:%dn",letters,space,digit,other); return 0; #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;#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; #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;#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);printf("n"); return 0;#define M 1000 /*定义寻找范围*/ #include <stdio.h>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=1;i<a;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;/*找出的笫 9 个因子赋给 k9 */case 10:k10=i;break;/* 找出的笫 10 个因子赋给 k10 */if (s=0)printf("%d ,Its factors are ",a);if (n>1)printf("%d,%d",k1,k2);/* n>1 表示 a 至少有 2 个因子 */if (n>2)printf(",%d",k3);/* n>2 表示至少有 3 个因子,故应再输出一个因子 */if (n>3)printf(",%d",k4);/* n>3 表示至少有 4 个因子,故应再输出一个因子 */if (n>4)printf(",%d",k5);/*以下类似 */if (n>5)printf(",%d",k6);if (n>6)printf(",%d",k7);if (n>7)printf(",%d",k8);if (n>8)printf(",%d",k9);if (n>9)printf(",%d",k10);printf("n");return 0; #include <stdio.h>int main() int m,s,i;for (m=2;m<1000;m+)s=0;for (i=1;i<m;i+)if (m%i)=0) s=s+i; if(s=m)printf("%d,its factors are ",m); for (i=1;i<m;i+)if (m%i=0) printf("%d ",i); printf("n");return 0;#include <stdio.h> int main()int i,n=20;double a=2,b=1,s=0,t; for (i=1;i<=n;i+)s=s+a/b;t=a,a=a+b,b=t;printf("sum=%16.10fn",s); return 0;#include <stdio.h> int main()double