资源描述
C 语言课后习题答案-第四版- 谭浩强(1-7)
第一章
#include <stdio.h>
int main ( )
{ printf ("**************************\n\n"); printf(" Very Good!\n\n");
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 %d\n",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=%f\n",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=%f\n",p1);
// 输出按第 1
方案得到的本息和
printf("p2=%f\n",p2);
// 输出按第 2
方案得到的本息和
printf("p3=%f\n",p3);
// 输出按第 3
方案得到的本息和
printf("p4=%f\n",p4);
// 输出按第 4
方案得到的本息和
printf("p5=%f\n",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=%f\n",p1);
// 输出按第 1
方案得到的本息和
printf("p2=%f\n",p2);
// 输出按第 2
方案得到的本息和
printf("p3=%f\n",p3);
// 输出按第 3
方案得到的本息和
printf("p4=%f\n",p4);
// 输出按第 4
方案得到的本息和
printf("p5=%f\n",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.2f\n",p1); // 输出按第 1 方案得到的本息和
printf("p2=%10.2f\n",p2); // 输出按第 2 方案得到的本息和
printf("p3=%10.2f\n",p3); // 输出按第 3 方案得到的本息和
printf("p4=%10.2f\n",p4); // 输出按第 4 方案得到的本息和
printf("p5=%10.2f\n",p5); // 输出按第 5 方案得到的本息和
return 0;
}
#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.2f\n",m);
return 0;
}
#include <stdio.h>
int main() {int c1,c2; c1=197; c2=198;
printf("c1=%c,c2=%c\n",c1,c2); printf("c1=%d,c2=%d\n",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=%c\n",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%c\n",c1,c2,c3,c4,c5);
return 0;
}
#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.2f\n",l);
printf("圆面积为: s=%6.2f\n",s);
printf("圆球表面积为: sq=%6.2f\n",sq);
printf("圆球体积为: v=%6.2f\n",vq);
printf("圆柱体积为: vz=%6.2f\n",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 %c\n",c1,c2);
return 0;
}
#include <stdio.h>
int main()
{
int c1,c2; //整型定义
printf("请输入两个整数 c1,c2:");
scanf("%d,%d",&c1,&c2);
printf("按字符输出结果:\n");
printf("%c,%c\n",c1,c2);
printf("按 ASCII 码输出结果为:\n");
printf("%d,%d\n",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,%c\n",i1,i2);
printf("按整数输出结果:\n");
printf("%d,%d\n",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,%c\n",c1,c2);
printf("按整数输出结果:\n");
printf("%d,%d\n",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=%d\n",c);
else
printf("max=%d\n",b);
else if (a<c)
printf("max=%d\n",c);
else
printf("max=%d\n",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("三个整数的最大数是%d\n",max); return 0;
} #include <stdio.h>
#include <math.h> #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 的平方根的整数部分是:%d\n",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 的平方根的整数部分是:%d\n",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=%d\n" ,x,y);
}
else if(x<10) /* 1=<x<10 */
{ y=2*x-1;
printf("x=%d, y=2*x-1=%d\n",x,y);
}
else /* x>=10 */ { y=3*x-11;
printf("x=%d, y=3*x-11=%d\n",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;
else
y=0;
printf("x=%d,y=%d\n",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=%d\n",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,相应的等级是%c\n ",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;
else if (num>999)
place=4;
else if (num>99)
place=3;
else if (num>9)
place=2; else place=1;
printf("位数:%d\n",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%d\n",indiv,ten,hundred,thousand,ten_thousand);
break;
case 4:printf("%d,%d,%d,%d",thousand,hundred,ten,indiv); printf("\n 反序数字为:"); printf("%d%d%d%d\n",indiv,ten,hundred,thousand); break;
case 3:printf("%d,%d,%d",hundred,ten,indiv); printf("\n 反序数字为:"); printf("%d%d%d\n",indiv,ten,hundred); break;
case 2:printf("%d,%d",ten,indiv); printf("\n 反序数字为:"); printf("%d%d\n",indiv,ten); break;
case 1:printf("%d",indiv); printf("\n 反序数字为:"); printf("%d\n",indiv); break;
}
return 0; }#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.2f\n",bonus);
return 0;
}
#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.2f\n",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=%d\n",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 <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("该点高度为 %d\n",h);
return 0;
}
第五章
#include <stdio.h>
#include <math.h>
// 程序中用到数学函数 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; // sign 代表符号,下一项的符号与上一项符号相反
term=sign/n; // 求出下一项的值 term
count++; // count 累加 1
}
pi=pi*4; // 多项式的和 pi 乘以 4,才是π的近似值
printf("pi=%10.8f\n",pi); // 输出π的近似值
printf("count=%d\n",count); // 输出循环次数
return 0;
}
#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("它们的最大公约数为:%d\n",n); printf("它们的最小公约数为:%d\n",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++;
else
other++;
}
printf("字母数:%d\n 空格数:%d\n 数字数:%d\n 其它字符数:%d\n",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+...=%d\n",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.15e\n",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.6f\n",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++)
展开阅读全文