好文档 - 专业文书写作范文服务资料分享网站

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

天下 分享 时间: 加入收藏 我要投稿 点赞

return 0; } 4-9

#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(位数:%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; }

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=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(奖金是: .2f\\n,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;

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(奖金是 .2f\\n,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=%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; } 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)+(y-y3)*(y-y3);

if (d1>1 && d2>1 && d3>1 && d4>1) h=0; /*判断该点是否在塔外*/ printf(该点高度为 %d\\n,h); return 0; }

第5章循环结构程序设计114 5.1为什么需要循环控制114 5.2用while语句实现循环115 5.3用do…while语句实现循环117 5.4用for 语句实现循环120 5.5循环的嵌套124 5.6几种循环的比较125 5.7改变循环执行的状态125 5.7.1用break语句提前终止循环126

5.7.2用continue语句提前结束本次循环127 5.7.3break语句和continue语句的区别128 5.8循环程序举例131 习题140 5-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; // sign代表符号,下一项的符号与上一项符号相反

term=sign/n; // 求出下一项的值term count++; // count累加1 }

pi=pi*4; // 多项式的和pi乘以4,才是π的近似值 printf(pi=.8f\\n,pi); // 输出π的近似值 printf(count=%d\\n,count); // 输出循环次数 return 0; } 5-3

#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(它们的最大公约数为:%d\\n,n); printf(它们的最小公约数为:%d\\n,p/n); return 0; } 5-4

#include int main()

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

return0;}4-9#include#includeintmain(){intnum,indiv,ten,hundred,thousand,ten_thousand,place;//分别代表个位,十位,百位,千位,万位和位数
推荐度:
点击下载文档文档为doc格式
8w0sl8dy3w2xc786b4a94zk8m0hvkq00s1m
领取福利

微信扫码领取福利

微信扫码分享