C语言程序设计第三版谭浩强课后习题答案.pdf

上传人:无*** 文档编号:88834756 上传时间:2023-05-04 格式:PDF 页数:120 大小:8.49MB
返回 下载 相关 举报
C语言程序设计第三版谭浩强课后习题答案.pdf_第1页
第1页 / 共120页
C语言程序设计第三版谭浩强课后习题答案.pdf_第2页
第2页 / 共120页
点击查看更多>>
资源描述

《C语言程序设计第三版谭浩强课后习题答案.pdf》由会员分享,可在线阅读,更多相关《C语言程序设计第三版谭浩强课后习题答案.pdf(120页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。

1、1.5 请参照本章例题,编写一个C程序,输出以下信息:Very Good!解:main()printf(“*)printf(n);printf(Very Good!nn);printf(n);prin,(”*”)1.6 编写一个程序,输 入 a、b、c 三个值,输出其中最大值.解:main()int a,b,c,max;printf(“请输入三个数 a,b,c:n);scanf(%d,%d1%d,11&a,&b,&c);max=a;if(maxb)max=b;if(maxc)max=c;printf(最大数为:d,max);第三章3.6 写出以下程序运行的结果.main()char c1=a,

2、c2=,b,c3=,c,c4=,101 1,c5=116;p rintf(a%cb%ctc%ctabcn,c 1,c2,c3);printf(utb%c%c”,c4,c5);)解:aa u bb LI u LI cc u u u u u u abcA u N3.7要 将China译成密码,译码规律是:用原来字母后面的第4个字母代替原来的字母.例如,字母A后面第4个字母是E.E代替A”.因此,China应译为Glmre.请编一程序,用赋初值的方法使cl、c2、c3、c4、c5五个变量的值分别为,C、h、i、n、a,经过运算,使c1、c2、c3、c4、c5分别变为G、,m、r、e,,并输出.解:i

3、nclude main()char c1=C,c2=h,c3=i,c4=n,c5=a;c1+=4;c2+=4;c3+=4;c4+=4;c5+=4;printf(密码是c%c%c%c%cn,c1,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=3,x=3.5,y=2.5(1)2.5(2)3.53.10写出程序运行的结果.main()int i,j,m,n;i=8;j=10;m=+i;n=j+;printf(d

4、,%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.4a=3,b=4,c=5,x=1.2,y=2.4,z=-3.6u=51274,n=128765lc1=,a,c2=lb.想得到以下输出格式和结果,请写出程序(包括定义变量类型和设计输出).a=3 b=4 c=5x=1.200000,y=2.40000

5、0,z=-3.600000 x+y=_3.600_y+z=-1.20_z+x=-2.40c1=a_or_97(ASCII)c2=b _or_98(ASCII)main()int a=3,b=4,c=5;long int u=51274,n=128765;float x=1.2,y=2.4,z=3.6;char c1=c&b=c(2)a|b+c&b-c(3)!(ab)&!c|1(4)!(x=a)&(y=b)&0(5)!(a+b)+c-1&b+c/2解:011(4)015.4有3个整数a、b、c,由键盘输入,输出其中最大的数.解:方法一include main()int a,b,c;printf(

6、请输入3个整数:);scanf(%d,%d,%d,&a,&b,&c);if(ab)if(bc)printf(max=%dn,c);else printf(max=%dn,b);else if(ac)printf(max=%dn,c);else printf(max=%dn,a);方法二:使用条件表达式,可以使程序更加简明、清晰.程序如下:include main()int a,b,c,temp,max;printf(请输入3 个整数:);scanf(%d,%d,%d,&a)&b,&c);temp=(ab)?a:b;/*将 a 和 b 中的大者存人tem p中*/max=(tempc)?temp

7、:c;/*将 a 和 b 中的大者与c 比较,取最大者*/printf(3个整数的最大数是dn”,max);5.5 有一函数:写一程序,输 入 x 值,输出v值.解:include main()int x,y;printf(输入 x:);scanf(%d,&x);/*x1 7 y=x;printf(x=%3d,y=x=%dn,x,y);else if(x10)/*1Wx-10 7 y=2*x-1;printf(x=%3d,y=2*x-1=%dn,x,y);else/*xe10 7 y=3*x-11;printf(x=%3d,y=3*x-11=%dn,x,y);5.6给一个百分制成绩,要求输出等

8、级TV、B、C、D、E.90分以上为,A,8090分为B,7079分为C,60分以下为D.解:程序如下:#include main()float score;char grade;printf(请输入学生成绩:);scanf(%f,&score);while(score100|(score0)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=iD,;break;

9、case 5:case 4:case 3:case 2:case 1:case 0:grade=E,;)printf(成绩是5.1f,相应的等级是c.rT,score,grade);说明:对输入的数据进行检查,如小于0 或大于100,要求重新输入.(int)(score/10)的作用是将(score/10)的值进行强制类型转换,得到一个整型值.5.7给定一个不多于5 位的正整数,要求:求它是几位数;分别打印出每一位数字;按逆序打印出各位数字.例如原数为321,应输出123.解:include main()long int num;int indiv,ten,hundred,thousand,t

10、en_thousand,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=1;printf(place=%dn,place);ten_thousand=num/10000;thousand=num/1000%10;hundred=num/100%10;ten=num%100/10;indiv=num%10;switc

11、h(place)case 5:printf(%d,%d,%d,%d,%d,ten_thousand,thousand,hundredsen,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,%

12、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;)5.8企业发放的奖金根据利润提成.利润I低于或等于10万元时,奖金可提成10%;利润高于10万元,低 于 2 0 万 元(1000001200000)时,其 中

13、10万元 按 10%提成,高 于 10万元的部分,可提成7.5%;2000001 400000时,其中2 0 万元仍按上述办法提成(下同),高于20万元的部分按5%提成;4000001 600000 时,高于 40 万元的部分按 3%提成;600000 1000000时,超 过 100万元的部分按1%提成.从键盘输入当月利润I,求应发放奖金总数.要求:(1)用 if语句编程序;(2)用 switch语句编程序.解:计算利润时,要特别注意不同利润的不同提成比例.例如,利润为15万元,其中有10万元按10%的比例提成,另外5 万元则按7.5%提成.(1)用 if语句编程序.include main

14、()long i;float bonus,bon1,bon2,bon4,bon6,bon10;bon1=100000*0.1;/*利润为10万元时的奖金*/*利润为2 0 万元时的奖金*/*利润为4 0 万元时的奖金*/*利润为60 万元时的奖金*/*利润为100万元时的奖金*/bon2=bon1+100000*0.075;bon4=bon2+200000*0.05;bon6=bon4+200000*0.03;bon10=bon6+400000*0.015;printf(请输入利润i:);scanf(%ld,&i);if(i=100000)bonus=i*0.1;/*利润在10万元以内按0.1

15、提成奖金*/else if(i=200000)bonus=bon1+(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 bon6 hon10;然后再加上各区间附加部分的奖金.(2)用switch语句编程序.输入利润i,确定相应的提成等级branch根据branch确定奖金值0 奖金=

16、i*0.11 奖金=bon1+(i-105)*0.0752 奖金=bon2+(i-2*105)*0.0534 奖金=bon4+(i-4*105)*0.0356 奖金=bon6+(i-6*105)*0.01578910 奖金=bon10+(i-106)*0.01输出奖金#include main()long i;float bonus,bon1,bon2,bon4,bon6,bon10;int c;bon1=100000*0.1;bon2=bon1+100000*0.075;bon4=bon2+200000*0.05;bon6=bon4+200000*0.03;bon10=bon6+400000

17、*0.015;printf(请输入利润i:);scanf(%ld,&i);c=i/100000;if(c10)c=10;switch(c)case 0:bonus=1*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:b

18、onus=bon10+(i-1000000)*0.01;)printf(奖金是10.2f,bonus);5.9输入4个整数,要求按由大到小的顺序输出.解:此题采用依次比较的方法排出其大小顺序.在学习了循环和数组以后,可以有更多的排序方法.include main()int t,a,b,c,d;printf(请输入4个整数:);scanf(%d,%d,%d,%d,&a,&b,&c,&d);printf(n 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=

19、c;c=t;if(bd)t=b;b=d;d=t;if(cd)t=c;c=d;d=t;printf(排序结果如下:n);printf(%d,%d,%d,%dn,a,b,c,d);)5.10有4个圆塔,圆心分别为(2,2)、(-2,2)、(2,-2)、(-2,-2),圆半径为1 .这4个塔的高度分别为10m.塔以外无建筑物.今输入任一点的坐标,求该点的建筑高度(塔外的高度为零).程序如下:include 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,

20、y):);scanf(%f,%f,&x,&y);d1=(x-x1)*(x-x1)+(y-y1)*(y-y1);/*求该点到各中心点的距离*/d2=(x-x2)*(x-x2)+(y+y2)*(y+y2);d3=(x+x3)*(x+x3)+(y-y3)*(y-y3);d4=(x+x4)*(x-x4)*(y+y4)*(y+y4);if(d11&d21&ad31&d41)h=0;/*判断该点是否在塔外*/printf(该点高度为小优1 1);第六章第六章循环控制6.1 输入两个正整数m 和 n,求其最大公约数和最小公倍数.main()long m,n,i=1,j,s;scanf(%ld,%ld,&m,

21、&n);for(;i=m&i=n)j=m;else j=n;for(;!(j%m=0&j%n=0);j+);printf(s=%ld,j=%ldn,s,j);6.2 输入一行字符,分别统计出其中英文字母、空格、数字和其他字符的个数.#includestdio.hmain()char c;int i=O,j=O,k=O,l=O;while(c=getchar()!=,n,)if(c=65&c=97&c=48&c=57)j+;else if(c=32)k+;else I+;printf(i=%d,j=%d,k=%d,l=%dn,i,j,k,l);6.3 求 Sn=a+aa+aaa+aa aaa(有

22、 n 个 a)之值,其中 a 是一个数字.例如:2+22+222+2222+22222(n=5),n 由键盘输入.#includemath.hmain()int n,sum=0,i=1,s=2;scanf(%d,&n);while(i=n)sum=sum+s;s=s+2*pow(10,i);i+;)printf(sum=%dn,sum);6.4 求,(即求 1 !+2!+3!+4!+5!+20!)main()int n,i=1;long sum=0,s=1;scanf(%d,&n);while(i=n)s=s*i;sum=sum+s;i+;printf(sum=%ldn,sum);6.5 求m

23、ain()double i=1,j=1,k=1,s1=0,s2=0,s3=0,sum;for(;i=100;i+)s1=s1+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(bJ3)+pow(c,3)printf(%5d,x);x+;)6.7 一个数如果恰好等于它的因子之和,这个数就称为“完数”.例如,6 的因子为 1、2、3,而 6=1+2+3,因此6 是完数.编程序找出1000之内的所有完数,并按下面格式输出其因子:6 its facto

24、rs are 1、2、3main()intfor(m=6;m10000;m+)s=1;for(i=2;im;i+)if(m%i=0)s=s+i;if(m-s=0)printf(%5d its fastors are 1 ,m);for(=2;jm;j+)if(m%j=0)printf(%d,j);printf(n);)或main()int m,i,j,s;for(m=6;m1000;m+)s=m-1;for(i=2;im;i+)if(m%i=O)s=s-i;if(s=O)printf(%5d its fastors are 1 ,m);for(j=2;jm;j+)if(m%j=0)printf

25、(%d,j);printf(n);6.8 有一分数序列:求出这个数列的前20项之和.main()int i=1,n;double t,x=1,y=2,s,sum=0;scanf(%ld,&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 i,n;double h=100,s=100;scanf(%d,&n);for(i=1;i=n;i+)h*=0.5;if(i=1)contin

26、ue;s=2*h+s;printf(h=%f,s=%fn,h,s);6.10 猴子吃桃问题.猴子第一天摘下若干个桃子,当即吃了一半,还不过瘾,又多吃了一个.第二天早上又将剩下的桃子吃掉一半,又多吃一个.以后每天早上都吃了前一天剩下的一半零一个.到第10天早上想再吃时,见只剩下一个桃子了.求第一天共摘多少桃子.main()int i=1,sum=0;for(;i=0.00001);printf(%.3fn,x1);)6.12 用牛顿迭代法求方程在1.5附近的根.main()double x,y;x=1.5;doy=2*x*x*x-4*x*x+3*x-6;x=x-y/(6*x*x-8*x+3);w

27、hile(y!=0);printf(x=%.3fn,x);)6.13 用二分法求方程在(-10,10)之间的根main()double x1,x2,y1,y2;x1=-10;x2=10;doy1=2*x1*x1*x1-4*x1*x1+3*x1-6;x1=x1-y1/(6*x1*x1-8*x1+3);while(y1!=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(x1=%.3f,x2=%.3fn,x1,x2);6.14打印以下图案*#includemath.hmain()int i

28、,j,k;for(i=0;i=3;i+)for(j=0;j=2-i;j+)printf(for(k=0;k=2*i;k+)printf(*);printf(n);)for(i=0;i=2;i+)for(j=0;j=i;j+)printf();for(k=0;k=4-2*i;k+)printf(*);printf(n);第七章第 七 章 数 组7.1用筛法求之内的素数.main()int i,j,a100;for(i=2;i100;i+)ai=i;for(j=2;j=i;j+)if(ai%j=O)break;if(ai-j=O)printf(%5d,ai);)printf(n);或#includ

29、emath.hmain()static int i,j,k,a98;for(i=2;i100;i+)ai=i;k=sqrt(i);for(j=2;j=ai;j+)if(j=k+1)printf(%5d,ai);printf(n);7.2用选择法对1 0个整数从小到大排序.main()int i,j,a10,t;for(i=0;i10;i+)scanf(%d,&ai);for(j=1;j10;j+)for(i=0;iai+1)t=ai+1;ai+1=ai;ai=t;for(i=0;i10;i+)printf(%5d,ai);或main()static int a10,i,j,k,t;for(i=

30、1;i11 ;i+)scanf(%d,&ai);for(j=1;j10;j+)for(i=1;iai+1)t=ai+1;ai+1=ai;ai=t;for(i=1;i11 ;i+)printf(%d,ai);printf(n);7.3求一个3 X 3 矩阵对角线元素之和.main()int i=0,j=0,a33,s1,s2;for(i=0;i3;i+)for(j=0;j3;j+)scanf(%d,&aij);s1=a00+a11+a22;s2=a02+a11+a20;printf(s1=%d,s2=%dn,s1,s2);)或main()(static int i,j,s1,s2,a33;for

31、(i=1;i=3;i+)for(j=1;j0;i-)if(aiai-1)t=ai-1;ai-1=ai;ai=t;for(i=0;i10;i+)printf(%5d,ai);printf(n);)或main()(static int a5=1,4,5,6,7;int i,t,b;scanf(%d,&b);for(i=0;i5;i+)if(b=ai)t=ai;ai=b;b=t;printf(%dprintf(%d,b);7.5将一个数组的值按逆序重新存放,例如,原来顺序为:8,6,5,4,1.要求改为:1,4,5,6,8.main()int i,b10;for(i=0;i-1;i-)printf(

32、%5d,bi);printf(n);7.6打印出以下杨辉三角形(要求打印出10行).11 11 2 113 3 11 4 6 4 11 5 10 10 5 1main()static int m,n,k,b1515;b01=1;for(m=1;m15;m+)for(n=1;n=m;n+)bmn=bm-1 n-1+bm-1 n;printf(%-5d,bmn);printf(n);或main()int i,j(n,k,a1010;static a1=1,1,1,1,1,1,1,1,1,1;a11=1;for(k=2,k11 ;k+)for(i=2;i=k;i+)for(j=2;j=i;j+)ai

33、j=ai-1j-1+ai-1j;for(k=1;k11 ;k+)for(i=1;i=k;i+)for(j=1;j=i;j+)printf(%d,aij);7.7 打印“魔方阵,所谓魔方阵是指这样的方阵,它的每一行、每一列和对角线之和均相等.例如,三阶魔方阵为8 1 63 5 74 9 2要求打印出由1n2的自然数构成的魔方阵.解:include main()int a1616,i,i,k,p,m,n;P=1;while(p=1)/*要求阶数为115的商数*/printf(Enter n(n=1 15):);scanf(%d,&n);if(n!=0)&(n=15)&(n%2!=0)p=0;)fo

34、r(i=1;i=n;i+)/*初始化*/for(j=1;j=n;j+)ai0=O;j=n/2+1;/*建立魔方阵7a1D=1;for(k=2;k=n*n;k+)(三Ej=j+1;if(in)i=i+2;j=H;)else if(in)j=1;)if(aij=O)aij=k;else i=i+2;;aij=k;)for(i=1;i=n;i+)for(j=1;j=n;j+)printf(%4d,aiU);printf(n);/*输出魔方阵*/7.8找出一个二位数组中的鞍点,即该位置上的元素在该行上最大,在该列上最小,也可能没有鞍点.main()int a55,b5,c5,d55,k=0,l=0;i

35、nt i,j;for(i=0;i5;i+)for(j=0;j5;j+)scanf(%d,&dij);for(i=0;i5;i+)forG=0;j5;j+,aij=di0);for(i=0,k=0;i5;i+,k+)for(j=0;j=aij+1)bk=ai0+1=aiU;elsebk=aij+1;)for(j=0,l=0;j5;j+,l+)for(i=0;i4;i+)if(aij=ai+1j)cl=ai+10=ai0;elsefor(i=0,k=0;i5;i+,k+)for(j=0,l=0;j5;j+,l+)if(di0-bk=O)if(dij-cl=O)printf(d%d%d=%dn,i,

36、j,dij);elseprintf(d%d%d=%d isnot andin,i,j,dij);7.9有 个 15数按由小到大顺序存放在一个数组中,输入一个数,要求用折半查找法找出该数组中第几个元素的值.如果该数不在数组中,则打印出 无此数“#includemath.hmain()static int ij.m.allS H I,4,9,13,21,34,55,89,144,233,377,570,671,703,812);scanf(%d,&m);for(j=0;j15;j+)printf(%4d,aj);printf(n);i=7;while(fabs(i-7)8)if(ma7)if(ai

37、-m=O)printf(it is at(%d)n,i+1);break;i+;elseprintf(8n);)if(fabs(i-7)-8=0)printf(There is notn);7.10有一篇文章,共有3 行文字,每行有个80字符.要求分别统计出其中英文大写字母、小写字母、空格以及其它字符的个数.main()int i,j=0,k=0,l=0,m=0,n=0;char str0301,str1 100,str2100,str3100;gets(strl);gets(str2);gets(str3);strcat(str0,str1);strcat(str0,str2);strcat

38、(str0,str3);for(i=0;str0i!=0,;i+)if(str0i=65&str0i=97&str0i=48&str0i=57)I+;else if(str0i=32)m+;else n+;printf(Daxie Xiaoxie Shuzi Kongge Qitan);printf(%5d%7d%5d%6d%4dn,j,k,l,m,n);7.11打印以下图案*main()int i,j,k;char a55;for(i=0;i5;i+)for(j=0;j5;j+)ai0=*);printf(%c,ai0);printf(n);for(k=1;kZ a-zB-Y b-yC-X

39、c-x即第一个字母变成第26个字母,第i个字母变成第(26-1+1)个字母.非字母字符不变,要求编程序将密码回原文,并打印出密码和原文.main()int i;char str1100,str2100;gets(strl);for(i=0;str1i!=0,;i+)if(str1i=65&str1i=97&str1 iS2,输出一个正数;S1=S2,输出0;S1S2,输出一个负数.不要用strcpy函数.两个字符串用gets函数读入.输出的正数或负数的绝对值应是相比较的两个字符串相对应字符的ASCII码的差值.例如,A与 相 比,由于A V C,应输出负数,由于TV与,C的码差值为2,因此应输

40、出-2.同理:And和Aid比较,根据第2个字符比较结果,h比 大5,因此应输出“5.include#include main()int i,resu;char s1100,s2100;printf(n input stringlgets(s1);printf(n Input string2:);gets(s2);i=0;while(s1 i=s2i&s1 i!=0,)i+;if(s1i=0,&s2i=0)resu=O;else resu=s1i-s2i;printf(n result:%dn,resu);7.15编写一个程序,将字符数组s2中的全部字符拷贝到字符数组s1中,不用strcpy函

41、数.拷贝时,0也要拷贝过去,0后面的字符不拷贝.解:include stdio.hmain()char s180,s280;int i;printf(lnput s2:);scanf(%s,s2);for(i=0;istrlen(s2);i+)s1i=s2i;printf(s1:%sn,s1);第八章第 八 章 函 数1.1写两个函数,分别求两个整数的最大公约数和最小公倍数,用主函数调用这两个函数,并输出结果两个整数由键盘输入.maxyueshu(m,n)int m,n;int i=1,t;for(;i=m&i=n)j=m;else j=n;for(;!(j%m=0&j%n=0);j+);re

42、turn j;main()int a,b,max,min;printf(enter two number is:);scanf(%d,%d,&a,&b);max=maxyueshu(a,b);min=minbeishu(a,b);printf(max=%d,min=%dn,max,min);)8.2求方程的根,用三个函数分别求当b2-4ac大于0、等于0、和小于0时的根,并输出结果.从主函数输入a、b、c的值.#includemath.hfloat yishigen(m,n,k)float m,n,k;float x1,x2;x1=(-n+sqrt(k)/(2*m);x2=(-n-sqrt(k

43、)/(2*m);printf(two shigen is x1=%.3f and x2=%.3fn,x1,x2);)float denggen(m,n)float m,n;float x;x=-n/(2*m);printf(denggen is x=%.3fn,x);float xugen(m,n,k)float m,n,k;float x,y;x=-n/(2*m);y=sqrt(-k)/(2*m);printf(two xugen is x1=%.3f+%.3fi and x2=%.3f-%.3fin,x,y,x,y);)main()float a,b,c,q;printf(input a

44、b c is);scanf(%f,%f,%f,&a,&b,&c);printf(n);q=b*b-4*a*c;if(q0)yishigen(a,b,q);else if(q=O)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=O&im)break;if(m-i=O)t=1;else t=0;return m;)main()int a,s;printf(enter sushu is n);scanf(%d,&a);s=ps

45、ushu(a);if(s=1)printf(a is sushun);else printf(s is not sushun);)8.4写一个函数,使给定的一个二维数组(3 X 3)转置,即行列互换.int zhuangzhi(b)int b33;intfor(i=0;i=i&j3-i;j+)t=biU;biO=bOi;bOi=t;main()int a33;int i.j;for(i=0;i3;i+)for(j=0;j3;j+)scanf(%d,&aij);for(i=0;i3;i+)for(j=0;j3;j+)printf(%d,aij);printf(n);zhuangzhi(a);fo

46、r(i=0;i3;i+)for(j=0;j-1;i+,j-)str1i=str2j;)8.6写一函数,将两个字符串连接.lianjie(a,b)char a100,b100;strcat(a,b);)main()char str1100,str2100;gets(str1);gets(str2);Iianjie(str1,str2);puts(strl);8.7 写一函数,将两个字符串中的元音字母复制到另一个字符串,然后输出.fuzhi(a,b)char a100,b100;int i,j=O;for(i=0;ai!=0,;i+)if(ai=97|ai=101|ai=105|ai=111|ai

47、=117|ai=65|ai=69|ai=73|ai=85)bO=ai;j+;)main()char str1100,str2100;gets(strl);fuzhi(str1,str2);puts(str2);8.8 写一函数,输入一个四位数字,要求输出这四个数字字符,但每两个数字间空格.如输入1990应输出T_9_9_0”.char f(b)char b4;int i=0;for(;i=65&str0i=97&str0i=48&str0i=57)b1+;else if(str0i=32)b2+;else b3+;main()char str1100;static int i,a4;gets(

48、strl);tongji(str1,a);printf(zimu Shuzi Kongge Qitan);for(i=0;i=97&str1 i=65&str1 i=t)strcpy(wordO,word 1);main()char strO100,longword15;gets(strO);cechang(strO,longword);puts(longword);8.11写一函数用起泡法对输入的个字符按由小到大的顺序排列.int paixu(x)int x;intfor(j=1;j10;j+)for(i=0;ixi+1)t=xi+1;xi+1=xi;xi=t;)main()int y1O;

49、int i;for(i=0;i10;i+)scanf(%d,&yi);paixu(y);for(i=0;i10;i+)printf(%5d,yi);printf(n);8.12 用牛顿迭代法求根.方程为:,系数a,b,c,d由主函数输入.求X 在 1 附近的一个实根.求出后由主函数输出.double qigen(s,t,u,v)int s,t,u,v;double x,y;x=1;doy=s*x*x*x+t*x*x+u*x+v;x=x-y/(3*s*x*x+2*t*x+u);while(y!=0);return x;main()int a,b,c,d;double x;scanf(%d,%d,

50、%d,%d,&a,&b,&c,&d);x=qigen(a,b,c,d);printf(x=%.3fn,x);)8.13 用递归方法求n 阶勒让德多项式的值递归公式为float p(xO,n)int n;float xO;float y;if(n=0|n=1)if(n=1)y=xO;else y=1;else y=(2*n-1)*x0*p(x0,n-1)-(n-1)*p(x0,n-2)/n;return(y);main()float x,yO;int a,i;scanf(%f,%d,&x,&a);yO=p(x,a);printf(y0=%.3fn,y0);)8.14输 入 10个学生5 门课的成

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 教育专区 > 教案示例

本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

工信部备案号:黑ICP备15003705号© 2020-2023 www.taowenge.com 淘文阁