《C语言程序设计第四版谭浩强课后习题答案.pdf》由会员分享,可在线阅读,更多相关《C语言程序设计第四版谭浩强课后习题答案.pdf(52页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、第三章3.6 写出以下程序运行的结果。main()char cl=a,c2=b,c3=c,c4=101,c5=,116z;printf(a%cb%ctc%ctabcn,cl,c2,c3);printf(tb%c%c,z c4f c5);)解:aa LJ bb L-I U U cc U U U U L-l U abcA U N3.6 要将China译成密码,译码规律是:用原来字母后面的第4 个字母代替原来的字母.例如,字母A后面第4 个字母是E.E代替A。因此,China”应译为Glmre 请编一程序,用赋初值的方法使cl、c2、c3、c4、c5五个变量的值分别为,C,、,h,、,n,、经过运算
2、,使 cl、c2,c3、c4、c5 分别变为,G,、rr,e:并输出。解:#include main()char cl=,C,,c2=,h,,c3=,i,,c4=,n,,c5=,a,;cl+=4;c2+=4;c3+=4;c4+=4;c5+=4;printf(密码是3c告 c%c传 ccn”,cl,c2,c3,c4,c5);运行结果:密码是Glmre3.9求下面算术表达式的值。(1)x+a%3*(int)(x+y)%2/4设 x=2.5,a=7,y=4.7(2)(float)(a+b)/2+(int)x%(int)y设 a=2,b=3rx=3.5,y=2.5(1)2.5(2)3.53.10写出程
3、序运行的结果。main()inti=8;j=10;m=+i;n=j+;printf(%d,招 d,%d,%d,i,j ,m,n);解:9,11,9,103.12写出下面表达式运算后a 的值,设原来a=12。设 a 和 n 都已定义为整型变量。(1)a+=a(2)a-=2(3)a*=2+3(4)a/=a+a(5)a%=(n%=2),n 的值等于 5(6)a+=a-=a*=a解:(1)24(2)10(3)60(4)0(5)0(6)0第四章4 4 若 a=3,b=4,c=5,x=l.2,y=2.4,z=-36,u=51274,n=128765,cl=a,c2=,b,。想得到以下输出格式和结果,请写出
4、程序(包括定义变量类型和设计输出)。a=3 b=4 c=5x=7.5odoo6,J=2.460000,z=-3,600000 x+y=_3,600_ _y+z=-l.20_ _z+x=-2.40cl=zaz_or_977ASCII)c2=,b,or98(ASCII)main()int a=3,b=4,c=5;long int u=51274 z n=1287 65;float x=l.2,y=2.4,z=3.6;char cl=a,c2=b;printf(Ha=%2d b=%2d c=%2dn”,a,b,c);printf(x=%f,y=%fz z=%fnHf xz yz z);printf(
5、Hx+y=%5.2f y+z=%5.2f z+x=第 5.2fn”,x+y,y+z,z+x);printf(nu=%61d n=%91dn,u,n);printf(H%s%s%d%sn ncl=zaz Hz Horn,cl,n(ASCII)n);printf(H%s%s 告 d3sn,c2=a,“or“,c2,”(ASC工 工)”);4.7 用 scanf 下面的函数输入数据,使 a=3,b=7,x=8.5,y=71.82,cl=A,c2=,a 问在键盘上如何输入?main()(int a,b;float x,y;char clc2;scanf(”a=%d_b=%d”,&a,&b);scanf
6、(H_x=%f_y=%en A&x,&y);scanf(n_cl=%c_c2=%cH,&cl,&c2);a=3_b=7_x=8.5_y=71.82_cl=A_c2=a4.8 设圆半径r=l.5,圆柱高h=3,求圆周长、圆面积、圆球表面积、圆球体积、圆柱体积。用 scanf输入数据,输出计算结果,输出时要求文字说明,取小数点后两位数字。请编程序。main()float r,h,Cl,Sa,Sb,Va,Vb;scanf(n%fz%fH/&rc&b=c(2)a|b+c&b-c(3)!(ab)&!c|11(4)!(x=a)&(y=b)&0(5)!(a+b)+c-l&b+c/2解:(1)0(2)1(3)
7、1(4)0(5)15.4 有 3 个整数a、b、c,由键盘输入,输出其中最大的数。解:方法一#include main()int a,b,c;printf(”请输入3 个整数:”);scant(n%d,%dr%d”,&a,&b,&c);if(ab)if(bc)printf(Hmax=%dnHz c);else printf(nmax=%dnn,b);else if(ac)printf(max=%dn”,c);else printf(”max=%dn”,a);方法二:使用条件表达式,可以使程序更加简明、清晰。程序如下:#include main()int a,b,c,temp,max;print
8、f(”请输入3 个整数:”);scanf(d,%db)?a:b;/*将 a 和 b 中的大者存人temp中*/max=(tempc)?temp:c;/*将 a 和 b 中的大者与c 比较,取最大者*/printf(3个整数的最大数是3dn,max);5.5 有一函数:写一程序,输入x 值,输出y 值。解:#include main()int x,y;printf(输入 x:);scanf(H%dn,&x);if(xl)y=x;printf(Hx=%3d,)else if(x10)y=2*x-l;printf(”x=%3d,else y=3*x-ll;printf(Hx=%3d,/*xl*/y=
9、x=%dn,x,y);/*l10*/y=3*x-ll=%dnH z x,y);5.6给一个百分制成绩,要求输出等级,A,、,D,、。90分以上为,A 8090分为,B,7079分为,C,60分以下为,DJ解:程序如下:#include main()float score;char grade;printf(请输入学生成绩:”);scanf(,&score);while(score100|(score0)printf(”n输入有误,请重新输入:H);scanf(n%f nz&score);switch(int)(score/10)case 10:case 9:grade=zAz;break;ca
10、se 8:grade=B;break;case 7:grade=C;break;case 6:grade=z Df/break;case 5:case 4:case 3:case 2:case 1:case 0:grade=E;)printf(成绩是5 13 相应的等级是c。n,score,grade);说明:对输入的数据进行检查,如小于0或大于100,要求重新输入。(int)(score/10)的作用是将(score/10)的值进行强制类型转换,得到一个整型值。5.7给定一个不多于5位的正整数,要求:求它是几位数;分别打印出每一位数字;按逆序打印出各位数字。例如原数为321,应输出123。解
11、:#include main()long int num;int indivz ten,hundred,thousand,ten_thousandz place;/*分别代表个位、十位、百位、千位、万位和位数*/printf(“请输入一个整数(0-99999):);scanf(%ld”,&num);if(num9999)place=5;else if(num999)place=4;else if(num99)place=3;else if(num9)place=2;else place=l;printf(nplace=%dn”,place);ten_thousand=num/10000;tho
12、usand=num/1000%10;hundred=num/100%10;ten=num%100/10;indiv=num%10;switch(place)case 5:printf(Sd,3d,3d,3d,%d”,ten_thousand,thousand,hundred,ten,indiv);printf(n 反序数字为:);printf(n%d%d%d%d%dnn,indiv,ten,hundred,thousand,ten_thousand);break;case 4:printf(3d,%d,%d,%dnrthousand,hundred,ten,indiv);printf(n反序数
13、字为:”);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(n%d,%dH,ten,indiv);printf(Hn反序数字为:”);printf(n%d%dnn rindiv,ten);break;case 1:printf(H%dn,indiv);printf(nn反序数字为:”);printf(n%dnn,i
14、ndiv);break;)5.8 企业发放的奖金根据利润提成。利润工低于或等于10万元时,奖金可提成10超;利润高于10万元,低于20万 元(100000CI4200000)时,其中10万元按10%提成,高于10万元的部分,可提成7.5当;20000014400000时,其中20万元仍按上述办法提成(下同),高于20万元的部分按5%提成;4000001000000时,超过100万元的部分按1%提成。从键盘输入当月利润工,求应发放奖金总数。要求:(1)用 if语句编程序;(2)用 switch语句编程序。解:计算利润时,要特别注意不同利润的不同提成比例。例如,利润为15万元,其中有10万元按10
15、3的比例提成,另外5 万元则按7.5%提成。(1)用 if语句编程序。#include main()long i;float bonus,bonl,bon2,bon4,bon6,bonlO;bonl=100000*0.1;/*利润为10万元时的奖金*/bon2=bonl+100000*0.075;/*利润为 20 万元时的奖金*/bon4=bon2+200000*0.05;/*利润为 40 万元时的奖金*/bon6=bon4+200000*0.03;/*利润为 60 万元时的奖金*/bonl0=bon6+4 00000*0.015;/*利润为 100 万元时的奖金/printf(请输入利润i:
16、);scanf(n%ldnz&i);if(i=100000)bonus=i*0.1;/*利润在10万元以内按01 提成奖金*/else if(i=200000)bonus=bonl+(i-100000)*0.075;/*利润在 10 万至 20 万元时的奖金*/else if(i=400000)bonus=bon2+(i-200000)*0.05;/*利润在 20 万至 40 万元时的奖金*/else if(i=600000)bonus=bon4+(i-400000)*0.03;/*利润在 40 万至 60 万元时的奖金*/else if(i=1000000)bonus=bon6+(i-600
17、000)*0.015;/*利润在 60 万至 100 万元时的奖金*/elsebonus=bonl0+(i-1000000)*0.01;/*利润在 100 万元以上时的奖金*/printf(奖金是 10.2fn,bonus);此题的关键在于正确写出每一区间的奖金计算公式。例如利润在10万元至20万时,奖金应由两部分组成:润为10万元时应得的奖金。即 100000 x0.1;0 万元以上部分应得的奖金。即(num-100000)X).075。同理,20万40万这个区间的奖金也应由两部分组成:润为20万元时应得的奖金,即 100000 X).1X10万X).075;0 万元以上部分应得的奖金,即(
18、num-200000)X).05。程序中先把10万、20万、40万、60万、100万各关键点的奖金计算出来,即 bonl、bon2、bon4、bon6、honlO;然后再加上各区间附加部分的奖金。(2)用 switch语句编程序。输入利润i,确定相应的提成等级branch根据branch确定奖金值0 奖金=i*0.11.奖金=bonl+(i-105)*0.0752.奖金=)0。112+(i-2*105)*0.0534=bon4+(i-4*105)*0.0356 奖金=bon6+(i-6*105)*0.01578910=bonl0+(i-106)*0.01输出奖金#include main()l
19、ong i;float bonus,bonl,bon2,bon4r bon6,bonlO;int c;bonl=100000*0.1;bon2=bonl+100000*0.075;bon4=bon2+200000*0.05;bon6=bon4+200000*0.03;bonl0=bon6+400000*0.015;printf(请输入利润i:n);scanf(n%ldHz&i);c=i/100000;if(c10)c=10;switch(c)case 0:bonus=l*0.1;break;case 1:bonus=bonl+(i-100000)*0.0757break;case 2:case
20、 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=bonl0+(i-1000000)*0.01;)printf(奖金是%10.2f”,bonus);5.9 输入4 个整数,要求按由大到小的顺序输出。解:此题采用依次比较的方法排出其大小顺序。在学习了循环和数组以后,可以有更多的排序方法。frinclude main()int t,a
21、,b,c,d;printf(请输入4 个整数:”);scanf(”d,%d,%d,&a,&b,&c,&d);printf(Hn a=%d,b=%d,c=%d,d=dn”,a,b,c,d);if(ab)t=a;a=b;b=t;if(ac)t=a;a=c;c=t;if(ad)t=a;a=d;d=t;if(bc)t=a;b=c;c=t;if(bd)t=b;b=d;d=t;if(cd)t=c;c=d;d=t;printf(排序结果如下:n);printf(H%d,%d,%dz%dn”,a,b,c,d);5.10 有 4 个圆塔,圆心分别为(2,2)、(-2,2)、(2,-2)、(-2,-2),圆半径为
22、1。这 4 个塔的高度分别为10m。塔以外无建筑物。今输入任一点的坐标,求该点的建筑高度(塔外的高度为零)。程序如下:#include main()int h=10;float xl=2,yl=2,x2=-2,y2=2,x3=-2ry3=-2,x4=-2,y4=-2,x,y,dl,d2,d3,d4;printf(”请输入一个点(x,y):”);scanf(f,&x,&y);dl=(x-xl)*(x-xl)+(y-yl)*(y-yl);/*求该点到各中心点的距离*/d2=(x-x2)*(x-x2)+(y+y2)*(y+y2);d3=(x+x3)*(x+x3)+(y-y3)*(y-y3);d4=(
23、x+x4)*(x-x4)*(y+y4)*(y+y4);if(dll&d2l&d3l&d4l)h=0;/*判断该点是否在塔外*/printf(该点高度为dn”,h);第六章第六章循环控制6.1 输入两个正整数m 和 n,求其最大公约数和最小公倍数。main()longscanf(”ld,&m,&n);for(;i=m&i=65&c=97&c=48&c=57)j +;else if(c=32)k+;else 1+;printf(Hi=%dz j=%d,k=%d,l=%dnH,if j,kz1);6.3 求 Sn=a+aa+aaa+.+aa.aaa(有n 个 a)之值,其中a 是一个数字。例如:2+
24、22+222+2222+22222(n=5),n 由键盘输入。#includemath.hnmain()int n,sum=0,i=lr s=2;scanf(H%dn,&n);while(i=n)sum=sum+s;s=s+2*pow(10z i);i+;printf(sum=Zdn”,sum);6.4 求,(即求 l!+2!+3!+4!+5!+.+20!)main()int nz i=l;long sum=0rs=l;scanf(d,&n);while(i=n)s=s*i;sum=sum+s;i+;printf(Hsum=%ldnnz sum);6.5 求main()double i=lrj
25、=lrk=l,sl=0rs2=0,s3=0,sum;for(;i=100;i+)sl=sl+i;for(;j=50;j +)s2=s2+j *j;for(;k=100&x1000)a=0.01*x;b=10*(0.01*x-a);c=x-100*a-10*b;if(x=(pow(a,3)+pow(b,3)+pow(c,3)printf(n%5dz x);x+;6.7 一个数如果恰好等于它的因子之和,这个数就称为 完数。例如,6 的因子为1、2、3,而 6=1+2+3,因此6 是“完数”。编程序找出1000之内的所有完数,并按下面格式输出其因子:6 its factors are 1、2、3ma
26、in()int m,i,j,s;for(m=6;m10000;m+)s=l;for(i=2;im;i+)if(m%i=0)s=s+i;if(m-s=0)printf(H%5d its fastors are 1 m);for(j=2;jm;j+)if(m%j=0)printf(H%d”,j);printf(”n);或main()int m,i,j,s;for(m=6;m1000;m+)s=m-l;for(i=2;im;i+)if(m%i=0)s=s-i;if(s=0)printf(H%5d its fastors are 1,m);for(j=2;jm;j+)if(m%j=0)printf(H
27、%d”,j);printf(nnn);6.8 有一分数序列:求出这个数列的前20项之和。main()int i=l,n;double t,x=l,y=2,s,sum=0;scanf(H%ldnz&n);while(i=n)s=y/x;sum=sum+s;t=y;y=y+x;x=t;i+;printf(%fn,sum);6.9 一球从100米高度自由下落,每次落地后返回原高度的一半,再落下。求它在第10次落地时共经过多少米?第 10次反弹多高?main()int iz n;double h=100z s=100;scanf(n%dnz&n);for(i=l;i=n;i+)h*=0.5;if(i=
28、l)continue;s=2*h+s;printf(”h=%f,s=%fnH z hz s);6.10 猴子吃桃问题。猴子第一天摘下若干个桃子,当即吃了一半,还不过瘾,又多吃了一个。第二天早上又将剩下的桃子吃掉一半,又多吃一个。以后每天早上都吃了前一天剩下的一半零一个。到第10天早上想再吃时,见只剩下一个桃子了。求第一天共摘多少桃子。main()int i=l,sum=0;for(;i=0.00001);printf(%.3fn”,xl);6.1 2 用牛顿迭代法求方程在1.5 附近的根。main()double xz y;x=l.5;doy=2*x*x*x-4*x*x+3*x-6;x=x-y
29、/(6*x*x-8*x+3);while(y!=0);printf(Hx=%.3fnH,x);)6.13 用二分法求方程在(-10,10)之间的根main()double xl,x2z ylz y2;xl=-10;x2=10;doyl=2*xl*xl*xl-4*xl*xl+3*xl-6;xl=xl-yl/(6*xl*xl-8*xl+3);)while(yl!=0);doy2=2*x2*x2*x2-4*x2*x2+3*x2-6;x2=x2-y2/(6*x2*x2-8*x2+3);while(y2!=0);printf(Hxl=%.3f,x2=%.3fn”,xl,x2);6.14 打印以下图案*#
30、in c lu d eHm ath.hHmain()in t i,j,k;fo r(i=0;i=3;i+)f o r(j=0;j=2-i;j+)p r in tf (H n);for(k=0;k=2*i;k+)p r in tf (n*n);p r i n t f(Hnn);fo r(i=0;i=2;i+)fo r(j=0;j=i;j+)p r in tf (H n);for(k=0;k=4-2*i;k+)p r in tf (H*n);p r in t f(nnn);)第七章第 七 章 数 组7.1 用筛法求之内的素数。main()in t i,j,a 100;fo r(i=2;i 1 0
31、0;i+)a i=i;f o r(j=2;j=i;j+)if(j i)i f (ai%j=0)break;i f (ai-j=0)p r in t f(n%5dH,a i );p r in t f(Hnn);)或#inclucieHm ath.hnmain()s ta tic in t i,j,k,a 9 8 ;fo r(i=2;i 100;i+)a i=i;k=s q r t(i);for(j=2;j=ai;j+)if(j=k+l)printf(H%5dnzai);printf(Hnn);)7.2用选择法对10个整数从小到大排序。main()int i,j z a 10,t;for(i=0;
32、i10;i+)scanf(n%dn,i );for(j=l;j10;j+)for(i=0;iai+l)t=ai+1;ai+l=ai;ai=t;for(i=0;i10;i+)printf(H%5dnA ai);或main()static int a 10z iz j z kz t;for(i=l;ill;i+)scanf(n%dHz&ai);for(j=l;j10;j+)for(i=l;iai+l)t=ai+1;ai+l=ai;ai=t;for(i=l;ill;i+)printf(M%dnzai);printf(n);7.3求一个3x3矩阵对角线元素之和。main()int i=0,j=0,a3
33、3,si,s2;for(i=0;i3;i+)for(j=0;j3;j+)scanf(H%dMz&aij);sl=a0 0+all+a2 2;s2=a02+all+a20;printf(nsl=%d,s2=%dn,si,s2);或main()(static int i,j z si,s2,a 3 3;for(i=l;i=3;i+)for(j=l;j0;i-)if(aiai-l)t=ai-1;ai-l=ai;ai=t;for(i=0;i10;i+)printf(H%5dn z a i);printf(HnH);或main()(static int a 5=1,4,5,6,7;intscanf(%d
34、,&b);for(i=0;i5;i+)if(bt=ai;ai=b;b=t;printf(H%d,a i);printf(”d”,b);7.5 将一个数组的值按逆序重新存放,例如,原来顺序为:8,6,5,4,l o要求改为:1,4,5,6,8omain()int i,b10;for(i=0;i-l;i)printf(n%5dbi);printf(Hnn);7.6打印出以下杨辉三角形(要求打印出1 0行)。11.11.211.3311.46411.510105main()static int m,nfk,b1515;b01=1;for(m=l;m15;m+)for(n=l;n=m;n+)b m n
35、=b m-1 n-1 +b m-1 n;printf(n%-5dn,bmn);Jprintf(nnn);)或m ain()in t iz j z nz k,a 10 1 0;s t a t i c a 1=1Z lz 1 lz 1,1,l)z D H D H D );a l1=1;fo r(k=2 rk ll;k+)f o r(i=2;i=k;i+)f o r(j=2;j=i;j+)a i j=a i-l j-l +a i-l j;f o r(k=l;k ll;k+)f o r(i=l;i=k;i+)f o r(j=l;j=i;j+)p r i n t f (,r%d%ai j );7.7打印
36、、魔方阵,所谓魔方阵是指这样的方阵,它的每一行、每一列和对角线之和均相等。例如,三阶魔方阵为8 163 5 74 9 2要求打印出由1n 2的自然数构成的魔方阵。解:#in c lu d e m ain()in t a 1 6 1 6,i,i,k,p,m,n;p=l;w h ile(p=l)p r in tf (HE n te r n(n=l 1 5):scan f(%d,&n);i f(n!=0)&(n=15)&(n%2!=0)fo r(i=l;i=n;i+)fo r(j=l;j=n;j+)a i j=0;j=n/2+l;a l j =l;fo r(k=2;k=n*n;k+)i=i-l;i
37、f(i n)i=i+2;e ls e i f (in)j=l;i f (a i j=0)a i j=k;e ls e/*要求阶数为11 5的商数/p=0;/*初始化*/*建立魔方阵*/i=i+2;a i j=k;for(i=l;i=n;i+)/*输出魔方阵*/for(j=l;j=n;j+)printf(H%4dnzaij);printf(HnH);)7.8 找出一个二位数组中的鞍点,即该位置上的元素在该行上最大,在该列上最小,也可能没有鞍点。main()int a 55rb 5,c 5,d 55zk=0,1=0;int i,j;for(i=0;i5;i+)for(j=0;j5;j+)scanf
38、(M%dnzij);for(i=0;i5;i+)for(j=0;j5;j+zaij=dij);for(i=0z k=0;i5;i+,k+)for(j=0;j=aij+1)bk=ai j+l=ai j;elsebk=ai j +1;for(j=0z1=0;j5;j+,1+)for(i=0;i4;i+)if(ai j=ai+l j)cl=ai+lj=ai j;elsecl=ai+l j;for(i=0,k=0;i5;i+,k+)for(j=0,1=0;j5;j+,1+)if(di j-bk=0)if(dij-cl=0)printf(M%d%d=%dnMz jzdi j);elseprintf(nd
39、%d%d=%d isnot andin,i,j,d ij);7.9 有个15数按由小到大顺序存放在一个数组中,输入一个数,要求用折半查找法找出该数组中第几个元素的值。如果该数不在数组中,则打印出 无此数#includenmath.hHmain()static inta 15=1,4,9,13,21,34,55,89,144,233,377,570,671,703,812;scanf(%d,&m);for(j=0;j15;j+)printf(H%4dnAaj);printf(Hnn);i=7;while(fabs(i-7)8)if(ma7)if(ai-m=0)printf(Hit is at(%
40、d)nH,i+1);break;i+;elseprintf(H8nH);)if(fabs(i-7)-8=0)printf(HThere is notnH);)7.10 有一篇文章,共有3 行文字,每行有个80字符。要求分别统计出其中英文大写字母、小写字母、空格以及其它字符的个数。main()int i,j=O,k=0,1=0,m=0,n=0;charstrO301z strl100z str2100,str3 100;gets(strl);gets(str2);gets(str3);strcat(strO,strl);strcat(strO,str2);strcat(strO,str3);fo
41、r(i=0;strOi!=0,;i+)if(str0i=65&str0i=97&str0i=48&str0i=57)1+;else if(strOi=32)m+;else n+;printf(HDaxie Xiaoxie Shuzi Kongge Qitann);printf(H%5d%7d%5d%6d%4dnH,j,k,1zm,n);7.11 打印以下图案*main()int i,j,k;char a 5 5;for(i=0;i5;i+)for(j=0;j5;j+)aij=*;printf(n%cnfaij);printf(HnH);for(k=l;kZ a-zB-Y b-yC-X c-x即
42、第一个字母变成第26个字母,第 i 个字母变成第(26-i+l)个字母。非字母字符不变,要求编程序将密码回原文,并打印出密码和原文。main()int i;char strl100z str2100;gets(strl);for(i=0;strli!=0;i+)if(strli=65&strli=97&strliS2,输出一个正数;S1=S2,输出 0;S K S 2,输出一个负数。不要用strcpy函数。两个字符串用gets函数读入。输出的正数或负数的绝对值应是相比较的两个字符串相对应字符的ASC1工码的差值。例如,A,与,C,相比,由于,A Y V应输出负数,由于,A,与,的码差值为2,因
43、此应输出-2。同理:And和Aid”比较,根据第2 个字符比较结果,n,比,i,大 5,因此应输出5。include include main()int iz resu;char sl100,s2100;printf(n input stringl:H;gets(si);printf(n Input string2:n);gets(s2);i=0;while(sii=s2i&sli!=0,)i+;if(sli=0&s2i=0)resu=0;else resu=sli-s2 i;printf(Hn result:%dnu,resu);7.15编写一个程序,将字符数组s2中的全部字符拷贝到字符数组
44、si中,不用strcpy函数。拷贝时,0,也要拷贝过去,0,后面的字符不拷贝。解:#include nstdio.hnmain()char sl80,s280;int i;printf(nInput s2:H);scanf(H%snf s2);for(i=0;istrlen(s2);i+)sli=s2i;printf(nsl:%snH,si);第八章第 八 章 函 数1.1 写两个函数,分别求两个整数的最大公约数和最小公倍数,用主函数调用这两个函数,并输出结果两个整数由键盘输入。maxyueshu(m,n)int m,n;int i=lz t;for(;i=m&i=n)j=m;else j=n
45、;for(;!(j%m=0&j%n=0);j +);return j ;)main()int a,b,max,min;printf(nenter two number is:H);scanf(d,%d”,&a,&b);max=maxyueshu(a,b);min=minbeishu(a,b);printf(nmax=%dz min=%dnH,max,min);8.2求方程 的根,用三个函数分别求当b2-4ac大于0、等于0、和小于0 时的根,并输出结果。从主函数输入a、b、c 的值。#includeHmath.hHfloat yishigen(mz n,k)float m,n,k;float
46、xlz x2;xl=(-n+sqrt(k)/(2*m);x2=(-n-sqrt(k)/(2*m);printf(two shigen is xl=%.3f and x2=%.3fnn,xl,x2);float denggen(mz n)float m,n;float x;x=-n/(2*m);printf(Hdenggen is x=%.3fnn,x);float xugen(m,n,k)float m,n,k;float xz y;x=-n/(2*m);y=sqrt(-k)/(2*m);printf(two xugen is xl=%.3f+%.3fi and x2=%.3f-%.3finx
47、zy0)yishigen(a,q);else if(q=0)denggen(a,b);else xugen(a,b,q);8.2写一个判断素数的函数,在主函数输入一个整数,输出是否是素数的消息。psushu(m)int m;int i=2,t;for(;i=m;i+)if(m%i=0&im)break;if(m-i=0)t=l;else t=0;return m;main()int a,s;printf(nenter sushu is nH);scanf(d,&a);s=psushu(a);if(s=l)printf(a is sushunH);else printf(ns is not su
48、shunH);)8.4写一个函数,使给定的一个二维数组(3*3)转置,即行列互换。int zhuangzhi(b)int b33;int i,j r t;for(i=0;i=i&j3-i;j+)t=bij;bij=bji;bji=t;)main()int a 3 3;int iz j ;for(i=0;i3;i+)f o r(j=0;j 3;j+)s c a n f(n%dnz&a i j );f o r (i=0;i 3;i+)f o r (j=0;j 3;j+)p r i n t f (H%d”,a i j );p r i n t f (H nn);z h u a n g z h i(a)
49、;f o r (i=0;i 3;i +)f o r (j=0;j-l;i+,j 一)s t r l i =s t r 2 j ;8.6 写一函数,将两个字符串连接。l i a n j i e(a,b)c h a r a 1 0 0 zb 1 0 0 ;s t r c a t(a,b);m a i n ()c h a r s t r l 1 0 0 rs t r 2 1 0 0 ;g e t s(s t r l);g e t s(s t r 2);l i a n j i e(s t r l,s t r 2);p u t s(s t r l);8.7 写一函数,将两个字符串中的元音字母复制到另一个
50、字符串,然后输出。f u z h i(a,b)c h a r a 1 0 0 zb 1 0 0 ;i n t i,j=0;f o r (i=0;a i !=z 0z;i+)i f(a i =97|a i =1 0 1|a i =1 0 5|a i =l l l|a i =1 1 7|a i =6 5|Ia i =6 9|a i =7 3|a i =8 5)b j =a i ;j+;)m a i n ()c h a r s t r l 1 0 0 z s t r 2 1 0 0 ;g e t s(s t r l);f u z h i(s t r l,s t r 2);p u t s(s t r