admin 管理员组文章数量: 887021
2023年12月24日发(作者:软件工程技术与软件工程的区别)
C 语言课后习题答案-第四版- 谭浩强(1-7)
第一章
#include
int main ( )
{ printf ("**************************nn");
printf(" Very Good!nn");
printf ("**************************n");
return 0;
}
#include
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
max=b;
if (max max=c; printf("The largest number is %dn",max); return 0; } 第 3 章 #include #include int main() {float p,r,n; r=0.1; n=10; p=pow(1+r,n); printf("p=%fn",p); return 0; } #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); p2=p*(1+2*r2)*(1+3*r3); p3=p*(1+3*r3)*(1+2*r2); p4=p*pow(1+r1,5); p5=p*pow(1+r0/4,4*5); printf("p1=%fn",p1); printf("p2=%fn",p2); printf("p3=%fn",p3); printf("p4=%fn",p4); printf("p5=%fn",p5); return 0; } #include #include // 一次存 5 年期 // 先存 2 年期,到期后将本息再存 3 年期 // 先存 3 年期,到期后将本息再存 2 年期 // 存 1 年期,到期后将本息存再存 1 年期,连续存 5 次// 存活期存款。活期利息每一季度结算一次 // 输出按第 1 方案得到的本息和 // 输出按第 2 方案得到的本息和 // 输出按第 3 方案得到的本息和 // 输出按第 4 方案得到的本息和 // 输出按第 5 方案得到的本息和 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); p2=p*(1+2*r2)*(1+3*r3); p3=p*(1+3*r3)*(1+2*r2); p4=p*pow(1+r1,5); p5=p*pow(1+r0/4,4*5); printf("p1=%fn",p1); printf("p2=%fn",p2); printf("p3=%fn",p3); printf("p4=%fn",p4); printf("p5=%fn",p5); return 0; } // 一次存 5 年期 // 先存 2 年期,到期后将本息再存 3 年期 // 先存 3 年期,到期后将本息再存 2 年期 // 存 1 年期,到期后将本息存再存 1 年期,连续存 5 次// 存活期存款。活期利息每一季度结算一次 // 输出按第 1 方案得到的本息和 // 输出按第 2 方案得到的本息和 // 输出按第 3 方案得到的本息和 // 输出按第 4 方案得到的本息和 // 输出按第 5 方案得到的本息和 #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); p2=p*(1+2*r2)*(1+3*r3); p3=p*(1+3*r3)*(1+2*r2); p4=p*pow(1+r1,5); p5=p*pow(1+r0/4,4*5); printf("p1=%10.2fn",p1); printf("p2=%10.2fn",p2); printf("p3=%10.2fn",p3); printf("p4=%10.2fn",p4); printf("p5=%10.2fn",p5); return 0; // 一次存 5 年期 // 先存 2 年期,到期后将本息再存 3 年期 // 先存 3 年期,到期后将本息再存 2 年期 // 存 1 年期,到期后将本息存再存 1 年期,连续存 5 次// 存活期存款。活期利息每一季度结算一次 // 输出按第 1 方案得到的本息和 // 输出按第 2 方案得到的本息和 // 输出按第 3 方案得到的本息和 // 输出按第 4 方案得到的本息和 // 输出按第 5 方案得到的本息和 } #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; } #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; } #include 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 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 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 //计算圆面积 s //计算圆球表面积 sq //计算圆球体积 vq //计算圆柱体积 vz l=%6.2fn",l); s=%6.2fn",s); sq=%6.2fn",sq); 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; printf("圆周长为: printf("圆面积为: printf("圆球表面积为: printf("圆球体积为: v=%6.2fn",vq); vz=%6.2fn",vz); printf("圆柱体积为: return 0; } #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; } #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; }#include 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 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 int main() { int a,b,c; printf("请输入三个整数:"); scanf("%d,%d,%d",&a,&b,&c); if (a if (b printf("max=%dn",c); else printf("max=%dn",b); else if (a printf("max=%dn",c); else printf("max=%dn",a); return 0; }#include int main() { int a,b,c,temp,max; printf("请输入三个整数:"); scanf("%d,%d,%d",&a,&b,&c); temp=(a>b)?a:b; /*将 a 和 b 中的大者存入 temp 中*/ /*将 a 和 b 中的大者与 c 比较,取最大者*/ max=(temp>c)?temp:c; printf("三个整数的最大数是%dn",max); return 0; } #include #include #define M 1000 int 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 #include 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 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= { 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 { 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; } #include 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 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 #include 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; }#include 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; } #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; 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; } #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 (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; } #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)+(y-y3)*(y-y3); if (d1>1 && d2>1 && d3>1 && d4>1) h=0; /*判断该点是否在塔外*/ printf("该点高度为 %dn",h); return 0; } 第五章 #include #include int main() { int sign=1,count=0; double pi=0.0,n=1.0,term=1.0; term 代表当前项的值 while(fabs(term)>=1e-8) 次方 { // 程序中用到数学函数 fabs,应包含头文件 math.n // sign 用来表示数值的符号,count 用来统计循环次数 // pi 开始代表多项式的值,最后代表π的值, n 代表分母,// 检查当前项 term 的绝对值是否大于或等于 10 的(-6) pi=pi+term; n=n+2; // 把当前项 term 累加到 pi 中 // n+2 是下一项的分母 // sign 代表符号,下一项的符号与上一项符号相反 // 求出下一项的值 term // count 累加 1 sign=-sign; term=sign/n; count++; } pi=pi*4; // 多项式的和 pi 乘以 4,才是π的近似值 // 输出π的近似值 // 输出循环次数 printf("pi=%10.8fn",pi); printf("count=%dn",count); return 0; } #include int main() { int p,r,n,m,temp; printf("请输入两个正整数 n,m:"); scanf("%d,%d,",&n,&m); if (n { 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 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; } #include 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 {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 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 { 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 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 用来累计 a 的因子的个数 */ /* s 用来存放尚未求出的因子之和,开始时等于 a */ /* 检查 i 是否 a 的因子 */ /* 如果 i 是 a 的因子 */ /* n 加 1,表示新找到一个因子 */ /* s 减去已找到的因子,s 的新值是尚未求出的因子之和 */ /* 将找到的因子赋给 k1...k9,或 k10 */ {n=0; s=a;
版权声明:本文标题:c程序设计(第四版)谭浩强-课后答案(完整版) (1) 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.freenas.com.cn/free/1703410395h450125.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论