C語言程序設(shè)計(jì)(譚浩強(qiáng))第四版-課后答案_第1頁
C語言程序設(shè)計(jì)(譚浩強(qiáng))第四版-課后答案_第2頁
C語言程序設(shè)計(jì)(譚浩強(qiáng))第四版-課后答案_第3頁
C語言程序設(shè)計(jì)(譚浩強(qiáng))第四版-課后答案_第4頁
C語言程序設(shè)計(jì)(譚浩強(qiáng))第四版-課后答案_第5頁
已閱讀5頁,還剩237頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡介

1、C語言程序設(shè)計(jì)(譚浩強(qiáng))第四版 -課后答案printf第一章 程序設(shè)計(jì)和C語言 【第15頁】1-5#in elude int mai n ()(*、nn)printf(Very Good!nn);printf (*n);return 0;1-6 #inelude int mai n()int a,b,c,max;prin tf(please in put a,b,e: n);sea nf(%d,%d,%d, &a,&b,&c);max=a;if (maxb)max=b;if (maxc)max=c;prin tf(The largest n umber is %dn,max); return

2、0;第2章算法一一程序的靈魂【第36頁】暫無答案第3章最簡單的C程序設(shè)計(jì) -順序程序設(shè)計(jì)【第82頁】3-1#in clude #in clude int mai n()float p,r, n;r=0.1;n=10;p=pow(1+r, n);prin tf(p=%fn,p);return 0;3-2-1#in elude #in elude int mai n()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;p仁 p*(1+r5)*5);/ 一次存5年

3、期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方/輸出按第2方/輸出按第3方/輸出按第4方/輸出按第5方到期后將本息存再存1年期,連續(xù)存5次p5=p*pow(1+r0/4,4*5);/ 存活期存款活期利息每一季度結(jié)算一次prin tf(p 1= %fn,p1); 案得到的本息和prin tf(p2=%fn,p2);案得到的本息和prin tf(p3=%fn,p3); 案得到的本息和prin tf(p4=%fn,p4);

4、案得到的本息和prin tf(p5=%fn,p5);案得到的本息和return 0; 3-2-2#inelude #in elude int mai n()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;p仁 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年

5、期,到期后將本息存再存1年期,連續(xù)存5次p5=p*pow(1+r0/4,4*5);/存活期存款?;钇诶⒚恳患径冉Y(jié)算一次prin tf(p 1= %fn,p1);/輸出按第1方案得到的本息和prin tf(p2=%fn,p2);/輸出按第2方案得到的本息和prin tf(p3=%fn,p3);/輸出按第3方案得到的本息和prin tf(p4=%fn,p4);/輸出按第4方3prin tf(p5=%fn,p5);/輸出按第5方p1=p*(1+r5)*5);/ 一次存5年期p2=p*(1+2*r2)*(1+3*r3);/先存2年期,/先存3年期,案得到的本息和案得到的本息和return 0;3-2

6、-3 #in elude #in elude int mai n()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;p3=p*(1+3*r3)*(1+2*r2);到期后將本息再存2年期p4=p*pow(1+r1,5);/ 存 1 年期,到期后將本息存再存1年期,連續(xù)存5次p5=p*pow(1+r0/4,4*5);/ 存活期存款。活期利息每一季度結(jié)算一次printf(p1=%10.2fn,p1);/ 輸出按第1方案得到的本息和printf(p2=%10.2

7、fn,p2);/ 輸出按第2方案得到的本息和printf(p3=%10.2fn,p3);/ 輸出按第3方案得到的本息和printf(p4=%10.2fn,p4);/ 輸出按第4方案得到的本息和printf(p5=%10.2fn,p5);/ 輸出按第5方案得到的本息和return 0;3-3.#inelude #in elude int mai n()float d=300000,p=6000,r=0.01,m; m=log10(p/(p-d*r)/log10(1+r);prin tf(m=%6.2fn,m);return 0;3-4#in clude int mai n()in t c1,c2

8、;c1=197;c2=198;prin tf(c1=%c,c2=%cn,c1,c2);printf(c%d , c2=%dn,c1,c2); return 0;3-5#in elude int mai n()int a,b;float x,y;char c1,c2;sca nf(a=%d b=%d, &a,&b);sca nf(%f %e, &x,& y);sca nf(%c%c, &c1, &c2);prin tf(a=%d,b=%d,x=%f,y=%f,c 1=%c,c2=%c n,a,b,x,y,c1,c2);return 0;3-6#in clude int mai n()char c

9、仁C,c2=h,c3=i,c4= n,c5=a;c仁 c1+4;c2=c2+4;c3=c3+4;c4=c4+4;c5=c5+4;prin tf(passworis %c%c%c%c%cn,c1,c2,c3,c4,c5);return 0;3-7#inelude int mai n ()float h,r,l,s,sq,vq,v z;float pi=3.141526;printf(請輸入圓半徑r,圓柱高h(yuǎn) :);sca nf(%f,%f,&r,&h);/ 要求輸入圓半徑r和圓柱高h(yuǎn)l=2*pi*r;計(jì)算圓周長Is=r*r*pi;/ 計(jì)算圓面積ssq=4*pi*r*r;圓球表面積sqvq=3.0

10、/4.0*pi*r*r*r; 球體積vqvz=pi*r*r*h;圓柱體積vzprintf(圓周長為:printf(圓面積為: printf(”圓球表面積為: printf(圓球體積為: printf(圓柱體積為: return 0;3-8-1#inelude int mai n()int e1,e2;義/計(jì)算/計(jì)算圓/計(jì)算l=%6.2fn,l); s=%6.2fn,s); sq=%6.2fn,sq); v=%6.2fn,vq); vz=%6.2fn,vz);/整型定printf(請輸入兩個(gè)整數(shù) e1,e2:);sea nf(%d,%d,&c1, &c2);printf(按字符輸出結(jié)果:n);p

11、rin tf(%c,%cn,c1,c2);printf(按ASCII碼輸出結(jié)果為:n);prin tf(%d,%dn,c1,c2);return 0;3-8-2#in clude int mai n()char c1,c2;/ 定義字符型變量int i1,i2;定義整型變量printf(請輸入兩個(gè)字符c1,c2:);sca nf(%c,%c,&c1, &c2);i仁 c1;/賦值給整型變量i2=c2;printf(按字符輸出結(jié)果:n);c1,c2i1,i2;prin tf(%c,%cn,i1,i2); printf(”按整數(shù)輸出結(jié)果:n);prin tf(%d,%dn,c1,c2);retur

12、n 0;3-8-3 #inelude int mai n()char定義為字符型int定義為整型printf(請輸入兩個(gè)整數(shù)i1,i2:);sca nf(%d,%d,&i1,&i2);c1=i1;將整數(shù)賦值給字符變量c2=i2;printf(按字符輸出結(jié)果:n);prin tf(%c,%cn,c1,c2); printf(按整數(shù)輸出結(jié)果:n);prin tf(%d,%dn,c1,c2);return 0;3-8#in elude int mai n()char c1,c2;printf(請輸入兩個(gè)字符c1,c2:);c1=getchar();c2=getchar();printf(用putch

13、ar語句輸出結(jié)果為:);putchar(c1);putchar(c2);prin tf(n);printf(用printf語句輸出結(jié)果為:);prin tf(%c %cn,c1,c2);return 0;第4章選擇結(jié)構(gòu)程序設(shè)計(jì)【第111頁】4-4-1#in elude int mai n()int a,b,c;printf(請輸入三個(gè)整數(shù):); sca nf(%d,%d,%d, &a,&b,&c); if (ab)if (bc)prin tf(max=%dn,c); elseprin tf(max=%dn,b);else if (ac)prin tf(max=%dn,c); elseprin

14、tf(max=%dn,a); return 0;4-4-2#in clude int mai n() int a,b,c,temp,max;printf(請輸入三個(gè)整數(shù):);sca nf(%d,%d,%d, &a,&b,& c);temp=(ab)?a:b;/* 將a和b中的大者存入temp中*/max=(tempc)?temp:c;/* 將a和b中的大者與c比較,取最大者*/printf(三個(gè)整數(shù)的最大數(shù)是 %dn,max); return 0;4-5-2#in clude #in clude #defi ne M 1000int mai n()int i,k;printf(請輸入一個(gè)小于

15、%d的整數(shù)i:,M);sca nf(%d,&i);while (iM)printf(輸入的數(shù)不符合要求,請重新輸入一 個(gè)小于d的整數(shù)i:,M);sea nf(%d,&i);k=sqrt(i);printf(%d的平方根的整數(shù)部分是:%dn,i,k);return 0;4-5#inelude #in elude #defi ne M 1000int mai n()int i,k;printf(請輸入一個(gè)小于 %d的整數(shù)i:,M);sea nf(%d,&i);if (iM)printf(輸入的數(shù)不符合要求,請重新輸入一方根的整數(shù)部分個(gè)小于%d的整數(shù)i:,M); sca nf(%d,&i); k=s

16、qrt(i);prin tf(%d 的是:%dn,i,k); return 0;4-6.#in elude int mai n() int x,y;printf(輸入 x:); sca nf(%d, &x);if(x1) y=x;prin tf(x=%3d,else if(x10) y=2*x-1;/* x1 */y=x=%dn ,x,y);/* 1= x=10*/ y=3*x-11;prin tf(x=%d,y=3*x-1 仁 %dn,x,y);return 0;4-7-1#in clude int mai n()int x,y;prin tf(e nter x:);sca nf(%d, &

17、x);y=-1;if(x!=0)if(x0)y=1;elsey=0;prin tf(x=%d,y=%dn,x,y); return 0;4-7-2#inelude int mai n()int x,y;prin tf(please en ter x:);sea nf(%d, &x);y=0;if(x=0)if(x0) y=1;else y=-1;prin tf(x=%d,y=%dn,x,y);return 0;4-8#in elude int mai n() float score;char grade;printf(請輸入學(xué)生成績:); sca nf(%f, &score);while (s

18、core100|score0)prin tf(n輸入有誤,請重輸);sca nf(%f, &score);switch(i nt)(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,相應(yīng)的等級是cn,score,grade);return 0;4-9#in clude #in clude int mai

19、n()intn um,i ndiv,te n,hu ndred,thousa nd,te n_thousa nd, place;/分別代表個(gè)位,十位,百位,千位,萬位和位數(shù)printf(請輸入一個(gè)整數(shù)(0-99999):);sca nf(%d,&n um);if (n um9999)place=5;else if (num999)place=4;else if (num99)place=3;else if (num9)place=2;else place=1;printf(位數(shù):%dn,place);printf(每位數(shù)字為:);ten_thousa nd=n um/10000;thousa

20、nd=(i nt)( nu m-ten_thousa nd*10000)/1000;hundred=(int)(nu m-te n_thousa nd*10000-thousa nd*1000)/100;ten=(int)(n um-ten_thousa nd*10000-thousa nd*1000-hu ndred*100)/10;indiv=(int)(num-ten _thousa nd*10000-thousand*1000-hu ndred*100-te n*10);switch(place)case5:pri ntf(%d,%d,%d,%d,%d,ten_thousa nd,th

21、 ousa nd,h un dred,te n,i ndiv);printf(n反序數(shù)字為:);prin tf(%d%d%d%d%dn,i ndiv,te n,hu ndred, thousa nd,te n_thousa nd);break;case4:pri ntf(%d,%d,%d,%d,thousa nd,hu ndred,t en ,i ndiv);printf(n反序數(shù)字為:);prin tf(%d%d%d%dn,i ndiv,te n,hu ndred,tho usa nd);break;case3:pri ntf(%d,%d,%d,hu ndred,te n,in div);p

22、rintf(n反序數(shù)字為:);prin tf(%d%d%dn,i ndiv,te n,hu ndred); break;case 2:pri ntf(%d,%d,te n,i ndiv);printf(n反序數(shù)字為:);prin tf(%d%dn,i ndiv,te n);break;case 1:pri ntf(%d,i ndiv);printf(n反序數(shù)字為:);prin tf(%dn,i ndiv);break;return 0;4-10-1#in clude int mai n()int i;double bonu s,b on 1,b on 2,b on 4,b on 6,b on1

23、0;bo n仁 100000*0.1;bon 2=bo n1+100000*0.075;bon 4=bo n2+100000*0.05;bon 6=bo n4+100000*0.03;bo n10=bo n6+400000*0.015;printf(請輸入利潤i:);sea nf(%d,&i);if (i=100000)bonu s=i*0.1;else if (i=200000)bonus=bon 1+(i-100000)*0.075;else if (i=400000)bon us=bo n2+(i-200000)*0.05;else if (i=600000)bon us=bo n4+(

24、i-400000)*0.03;else if (i=1000000)bon us=bo n6+(i-600000)*0.015; elsebon us=bo n10+(i-1000000)*0.01; printf(獎(jiǎng)金是:%10.2fn,bonus); return 0;4-10-2#in clude int mai n()int i;double bonu s,b on 1,b on 2,b on 4,b on 6,b on 10;int bran ch;bo n仁 100000*0.1;bon 2=bo n1+100000*0.075;bon 4=bo n2+200000*0.05;bo

25、n 6=bo n4+200000*0.03;bo n10=bo n6+400000*0.015;printf(請輸入利潤i:);sca nf(%d,&i);bran ch=i/100000;if (bra nch10) bran ch=10;switch(bra nch) case 0:b onu s=i*0.1;break;case1:bo nus=bo n1+(i-100000)*0.075;break;case 2:case3:bon us=bo n2+(i-200000)*0.05;break;5:case 4:casebon us=bo n4+(i-400000)*0.03;brea

26、k;case 6:case 7:case 8:case9:bonu s=b on 6+(i-600000)*0.015;break;case 10: bonu s=bo n10+(i-1000000)*0.01;printf(獎(jiǎng)金是 %10.2fn,bonus);return 0;4-11#in clude int mai n()i nt t,a,b,c,d;printf(請輸入四個(gè)數(shù):);sca nf(%d,%d,%d,%d, &a,&b,&c, &d);prin tf(a=%d,b=%d,c=%d,d=%dn,a,b,c,d);if (ab) t=a;a=b;b=t;if (ac) t=a

27、;a=c;c=t;if (ad) t=a;a=d;d=t;if (bc) t=b;b=c;c=t;if (bd) t=b;b=d;d=t;if (cd) t=c;c=d;d=t;printf(排序結(jié)果如下:n);prin tf(%d%d%d%dn,a,b,c,d);return 0;4-12#in clude int mai n()h=0;/程序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(請輸入一個(gè)點(diǎn)(x,y):);sea nf(%f,%f, &x, &y);d仁(x-x4

28、)*(x-x4)+(y-y4)*(y-y4);/*求該點(diǎn)到各中心點(diǎn)距離*/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 (d11 & d21 & d31 & d41) /*判斷該點(diǎn)是否在塔外*/printf(該點(diǎn)高度為 %dn,h);return 0;第5章循環(huán)結(jié)構(gòu)程序設(shè)計(jì)【第140頁】5-2 #in clude #include 中用到數(shù)學(xué)函數(shù)fabs,應(yīng)包含頭文件 math.nint mai n()int sign=1,count=0;/ sig

29、n 用來表示數(shù)值的符號,count用來統(tǒng)計(jì)循環(huán)次數(shù)double pi=0.0,n=1.0,term=1.0;/ pi 開始代表多項(xiàng)式的值,最后代表n的值,n代表分母, term代表當(dāng)前項(xiàng)的值while(fabs(term)=1e-8)/ 檢查當(dāng)前項(xiàng)term的絕對值是否大于或等于10的(-6)次 方pi=pi+term;II 把當(dāng)前項(xiàng)term累加到pi中n=n+2;II n+2是下一項(xiàng)的分母sign=-sign;II sign 代表符號,下一項(xiàng)的符號與上一項(xiàng)符號相反term=sign/n;II 求出下一項(xiàng)的值termcoun t+;II count累加1/多項(xiàng)/輸出n/輸出循pi=pi*4;式的

30、和pi乘以4,才是n的近似值prin tf(pi=%10.8fn,pi);的近似值prin tf(co un t=%dn,cou nt); 環(huán)次數(shù)return 0;5-3 #in clude int mai n()int p,r, n,m,temp;printf(請輸入兩個(gè)正整數(shù)n,m:); sca nf(%d,%d,&n,&m);if (nm)temp=n;n=m;m=temp;p=n *m;while(m!=O)r=n %m;n=m;m=r;printf(它們的最大公約數(shù)為:%dn,n); printf(它們的最小公約數(shù)為:%dn,p/n); return 0;5-4#in clude i

31、nt mai n()char c;int letters=0,space=0,digit=0,other=0;printf(請輸入一行字符:n);while(c=getchar()!=n)if (c=a & c=A & c=0 & c=9) digit+;elseother+;printf(字母數(shù):dn 空格數(shù):dn 數(shù)字 數(shù):dn其 它 字 符數(shù):dn,letters,space,digit,other);return 0;5-5#in clude int mai n()inta,n ,i=1,s n=0,t n=0;prin tf(a, n=:);sca nf(%d,%d,&a,&n);w

32、hile (i=n)tn=tn+a;/*賦值后的tn為i個(gè)a組成數(shù)的值*/sn=sn+tn; /*賦值后的sn為多項(xiàng)式前i項(xiàng)之和*/a=a*10;+i;prin tf(a+aa+aaa+.=%dn,s n);return 0;5-6#inelude int mai n()double s=0,t=1;int n;for (n=1; n=20; n+)/*計(jì)算1到100的和*/*計(jì)算1到50各數(shù)的平/*計(jì)算1到10的各倒數(shù)t=t* n;s=s+1;prin tf(1!+2!+20!=%22.15en,s); return 0; 5-7#in elude int mai n()int n1=100

33、, n2=50, n3=10; double k,s1=0,s2=0,s3=0;for (k=1;k=n1;k+)s1= s1+k;for (k=1;k=n2;k+)方和*/s2=s2+k*k;for (k=1;k=n3;k+)和*/s3=s3+1/k;prin tf(sum=%15.6fn,s1+s2+s3);return 0;5-8#in elude int mai n()int i,j,k,n;prin tf(parcissus n umbers are );for (n=100; n1000; n+)i=n/100;j=n/10-i*10;k=n%10;if (n=i*i*i + j*

34、j*j + k*k*k)prin tf(%d ,n);prin tf(n);return 0;int k1,k2,k3,k4,k5,k6,k7,k8,k9,k10;int i,a, n,s;for (a=2;a=M;a+)的整數(shù),檢查它是否完數(shù)n=0;因子的個(gè)數(shù)*/s=a;求出的因子之和,開始時(shí)等于for (i=1;ia;i+)子*/if (a%i=0)子*/n+;到一個(gè)因子*/s=s-i;子,/* a是2-1000之間*/* n用來累計(jì)a的/* s用來存放尚未a */檢查i是否a的因/*如果i是a的因/* n加1,表示新找/* s減去已找到的因*/*s的新值是尚未求出的因子之和5-9-1#d

35、efine M 1000/*定義尋找范圍*/#in elude int mai n()switch( n)給 k1.k9,或 k10 */case 1:/*將找到的因子賦k1=i; break;/*找出的笫1個(gè)因子賦給k1 */case 2:k2=i; break;/*找出的笫2個(gè)因子賦給k2 */case 3:k3=i; break; /*找出的笫3個(gè)因子 賦給k3 */case 4:k4=i; break; /*找出的笫4個(gè)因子 賦給k4 */case 5:k5=i; break; /*找出的笫5個(gè)因子賦給k5 */case 6:k6=i;break;/*找出的笫6個(gè)因子賦給k6 */ca

36、se 7:k7=i;break;/*找出的笫7個(gè)因子賦給k7 */case 8:k8=i; break; /*找出的笫8個(gè)因子賦給k8 */case 9:k9=i; break; /*找出的笫9個(gè)因子賦給k9 */case 10:k10=i; break; /*找出的笫10個(gè)因子賦給k10 */if (s=0)prin tf(%d ,Its factors are ,a);if(n 1)prin tf(%d,%d,k1,k2);/* n1表示a至少有2個(gè)因子*/if (n 2)prin tf(,%d,k3);/* n2表示至少有3個(gè)因子,故應(yīng)再輸出一個(gè)因 子*/if (n 3)prin tf(

37、,%d,k4);/* n3表示至少有4個(gè)因子,故應(yīng)再輸出一個(gè)因子*/if(n 4)prin tf(,%d,k5);/*以下類似*/if (n 5)prin tf(,%d,k6);if (n 6)prin tf(,%d,k7);if (n 7)prin tf(,%d,k8);if (n 8)prin tf(,%d,k9);if (n 9)prin tf(,%d,k10);prin tf(n);return 0;5-9-2#in elude int mai n()int m,s,i;for (m=2;m1000;m+)s=0;for (i=1;im;i+)if (m%i)=0) s=s+i;if(

38、s=m)pri ntf(%d,its factors are ,m); for (i=1;im;i+)if (m%i=0)prin tf(%d ,i);prin tf(n);return 0;5-10#in clude int mai n()in t i,n=20;double a=2,b=1,s=0,t;for (i=1;i=n ;i+) s=s+a/b;t=a,a=a+b,b=t;prin tf(sum=%16.10fn,s);return 0;5-11#in elude int mai n()double sn=100,h n=sn/2;int n;for (n=2 ;n v=10; n

39、+)sn=sn+2*hn;/*第n次落地時(shí)共經(jīng)過的米數(shù)*/hn=hn/2;/*第n次反跳高度*/printf(第10次落地時(shí)共經(jīng)過 %f米n,sn);printf(第 10 次反彈 %f 米n,hn);return 0;5-12#in elude int mai n()int day,x1,x2;day=9;x2=1;while(day0)x仁(x2+1)*2;/*第1天的桃子數(shù)是第2天桃子數(shù)加1后的2倍.*/x2=x1;day-;prin tf(total=%dn,x1);return 0;5-13#in clude %5.2f#in elude int mai n()float a,x0,

40、x1;prin tf(e nter a positive n umber:); sea nf(%f, &a);x0=a/2;x仁(x0+a/x0)/2;dox0=x1;x( x0+a/x0)/2;while(fabs(x0-x1)=1e-5);prin tf(The square root is %8.5fn,a,x1);return 0;5-14#in elude #in elude int mai n()double x1,x0,f,f1;x1=1.5;dox0=x1;f=(2*x0-4)*x0+3)*x0-6;f1=(6*x0-8)*x0+3;x1= x0-f/f1;while(fabs

41、(x1-x0)=1e-5);printf(The root of equation is %5.2fn,x1); return 0;5-15#in clude #in clude int mai n()float x0,x1,x2,fx0,fx1,fx2;dopri ntf(e nter x1 & x2:);sca nf(%f,%f, &x1, &x2);fx仁 x1*(2*x1-4)*x1+3)-6;fx2=x2*(2*x2-4)*x2+3)-6;while(fx1*fx20);dox0=(x1+x2)/2; fx0=x0*(2*x0-4)*x0+3)-6;if (fx0*fx1)=1e-5

42、);prin tf(x=%6.2fn,x0);return 0;5-16#in clude int mai n()int i,j,k;for (i=0;i=3;i+)for (j=0;j=2-i;j+)printf();for (k=0;k=2*i;k+)prin tf(*);prin tf(n);for (i=0;i=2;i+)for (j=0;j=i;j+)printf();for (k=0;k=4-2*i;k+)prin tf(*);prin tf(n);return 0;5-17#inelude int mai n()char i,j,k;/*是a的對手;j是b的對手;k是c的對手*/

43、for (i=x:i=z:i+)for (j=x;j=z;j+)if (i!=j)for (k=x:k=z:k+)if (i!=k & j!=k)if (i!=x & k!=x & k!=z)prin tf(A-%cnB-%cnC-%cn,i,j,k);return 0;第6章利用數(shù)組處理批量數(shù)據(jù)【第168頁】6-1#inelude #in clude int mai n()int i,j,n,a101;for (i=1;i=100;i+)ai=i;a1=0;for (i=2;isqrt(100);i+)for (j=i+l;j=lOO;j+) if(ai!=0 & aj!=0) if (aj

44、%ai=0) aj=0;prin tf(n);for (i=2, n=0;i=100;i+) if(ai!=0)pri ntf(%5d,ai); n+;if(n=10)pri ntf(n); n=0;pri ntf(n); return 0;6-2#in elude int mai n()int i,j,mi n,temp,a11;prin tf(e nter data: n);for (i=1;i=10;i+)pri ntf(a%d=,i);sea nf(%d,&ai);prin tf(n);prin tf(The orgi nal nu mbers:n);for (i=1;i=10;i+)

45、prin tf(%5d,ai);prin tf(n);for (i=1;iaj) min=j;temp=ai;ai=ami n;ami n=temp;prin tf(nThe sorted n umbers:n);for (i=1;i=10;i+)prin tf(%5d,ai);prin tf(n);return 0;6-3#in clude int mai n()int a33,sum=0;int i,j;prin tf(e nter data: n);for (i=0;i3;i+)for (j=0;j3;j+)sca nf(%3d,&aij);for (i=0;i3;i+) sum=sum

46、+aii;prin tf(sum=%6dn,sum);return 0;6-4#in elude int mai n() int a11=1,4,6,9,13,16,19,28,40,100;int temp1,temp2, nu mber,e nd,i,j;prin tf(array a:n);for (i=0;ie nd)a10=n umber;elsefor (i=0;inu mber)temp1=ai;ai=nu mber;for (j=i+1;j11;j+)temp2=aj;aj=temp1;temp仁temp2;break;prin tf(Now array a:n);for (i

47、=0;i11;i+)prin tf(%5d,ai);prin tf(n);return 0;6-5#in clude #defi ne N 5int mai n() int aN,i,temp;prin tf(e nter array a: n);for (i=0;iN;i+)sea nf(%d,&ai);prin tf(array a:n);for (i=0;iN;i+)prin tf(%4d,ai);/循環(huán)的作用for (i=0;iN/2;i+) 是將對稱的元素的值互換 temp=ai; ai=aN-i-1; aN-i-1=temp;prin tf(nN ow,array a: n); f

48、or (i=0;iN;i+)prin tf(%4d,ai);prin tf(n); return 0;6-6#inelude #defi ne N 10int mai n() int i,j,aNN;for (i=0;iN;i+)ai【i=1; ai0=1;for (i=2;iN;i+)for (j=1;j=i-1;j+)aij=ai-1j-1+ai-1j;for (i=0;iN;i+)for (j=0;j=i;j+)prin tf(%6d,aij);prin tf(n);prin tf(n);return 0;6-7#inelude int mai n() int a1515,i,j,k,p

49、, n;p=1; while(p=1)printf(enter n(n=1-15):);sea nf(%d,&n);if (n!=0) & (n=15) & (n %2!=0)p=0;for (i=1;i=n ;i+)for (j=1;j=n ;j+)aij=0;j=n /2+1;a1j=1;for (k=2;k=n*n ;k+)i=i-1;j=j+1;if (in)i=i+2;j=j-1;elseif (in) j=1;if (aij=O)aij=k;elsei=i+2;j=j-1; aij=k;for (i=1;i=n ;i+)for (j=1;j=n;j+)prin tf(%5d,aij

50、); prin tf(n);return 0;6-8#in clude #defi ne N 4#define M 5/*數(shù)組為4行5列*/int mai n()int i,j,k,aNM,max,maxj,flag;prin tf(please in put matrix:n);for (i=0;iN;i+)for (j=0;jM;j+)sea nf(%d, &aij);for (i=0;iN;i+)max=ai0;設(shè)ai0最大*/maxj=0;賦給maxj保存*/for (j=0;jmax) max=aij;數(shù)存放在 max中*/maxj=j;在的列號存放在maxj中*/*輸入數(shù)組*/*開

51、始時(shí)假/*將列號0/*找出第i行/*將本行的最大/*將最大數(shù)所flag=1;鞍點(diǎn),以flag為1代表*/*先假設(shè)是/*如果flagfor (k=0;kakma刈)/*將最大數(shù)和其同列元素相比*/flag=0;/* 如果 max 不是同列最小,表示不是鞍點(diǎn)令flagl為0 */con ti nu e;if(flag)/* 如果 flag1 為1表示是鞍點(diǎn)*1pri ntf(a%d%d=%dn,i,maxj,max);/*輸出鞍點(diǎn)的值和所在行列號*/break;if(!flag)為0表示鞍點(diǎn)不存在*/prin tf(It is not exist!n); return 0;6-9#in elude

52、 #defi ne N 15int mai n() int i,n umber,top,bott,mid,loca,aN,flag=1,sig n; char c;prin tf(e nter data: n);sca nf(%d, &a0);i=1;while(i=ai-1)i+;elseprin tf(e nter this data aga in:n);prin tf(n);for (i=0;iN;i+)prin tf(%5d,ai);prin tf(n);while(flag)pri ntf(i nput nu mber to look for:);sea nf(%d,&nu mber

53、);sig n=0;top=0;/top是查找區(qū)間的起始位置bott=N-1;/bott是查找區(qū)間的最末位置if (n umberaN-1)要查的數(shù)不在查找區(qū)間內(nèi)loca=-1;/表示找不到while (!sign) & (top=bott)mid=(bott+top)/2;if (nu mber=amid) loca=mid;printf(Hasfound %d, its positionis %dn, nu mber,loca+1);sig n=1;else if (nu mberamid)bott=mid-1;elsetop=mid+1;if(!sig n|loca=-1)prin tf

54、(ca nnot find %d.n, number);prin tf(co ntinu or n ot(Y/N)?);sca nf( %c, &c);if (c=N|c= n) flag=0;return 0;6-10#in clude int mai n()i nt i,j,upp,low,dig,spa,oth;char text380;upp=low=dig=spa=oth=0;for (i=0;i3;i+) prin tf(please input line %d:n,i+1);gets(texti);for (j=0;j=A& textijv=Z)upp+;else if (tex

55、tij=a & textij=0 & textijv=9) dig+;else if (textij=)spa+;elseoth+;prin tf(nu pper case: %dn ,upp); prin tf(lower case: %dn,low);prin tf(other: %dn,oth);return 0;6-11#in elude int mai n() char a5=*,*T*T*,*;int i,j,k;char space=;for (i=0;i5;i+) prin tf(n); printf( );for (j=1;j=i;j+) prin tf(%c,space);

56、for (k=0;k5;k+) prin tf(%c,ak);prin tf(n);return 0;6-12a-c#in clude int mai n() int j,n;char ch80,tra n 80;prin tf(i nput cipher code:); gets(ch);prin tf(ncipher code:%s,ch);j=0;while (chj!=0) if (chj=A) & (chj=a) & (chj=z)tran j=219-chj;elsetra nj=chj;j+;n=j;prin tf(no rigi nal text:);for (j=0;j n;

57、j+)putchar(tra nj);prin tf(n);return 0;6-12b#in elude int mai n()int j,n;char ch80;prin tf(i nput cipher code: n);gets(ch);prin tf(ncipher code:%sn,ch);j=0;while (chj!=0) if (chj=A) & (chj=a) & (chj=z) chj=219-chj;elsechj=chj;j+;n=j;printf(original text:);for (j=0;j n;j+)putchar(chj);prin tf(n);retu

58、rn 0;6-13#in elude int mai n() char s180,s240;int i=0,j=0;prin tf(i nput stri ng1:);sca nf(%s,s1);prin tf(i nput stri ng2:);sca nf(%s,s2);while (s1i!=0)i+;while(s2j!=0)s1i+=s2j+;s1i=0;printf(nThe new string is:%sn,s1);return 0;6-14#in elude int mai n() int i,resu;char s1100,s2100;prin tf(i nput stri

59、 ng1:);gets(s1);prin tf(nin put stri ng2:);gets(s2);i=0;while (s1i=s2i) & (s1i!=0)i+;if (s1i=0 & s2i=0)resu=0;elseresu=s1i-s2i;prin tf(nresult:%d.n,resu);return 0;6- 15#in elude #inelude int mai n() char s180,s280;int i;prin tf(i nput s2:);sca nf(%s,s2);for (i=0;i=strle n( s2);i+)s1i=s2i;prin tf(s1:

60、%sn,s1);return 0;第7章用函數(shù)實(shí)現(xiàn)模塊化程序設(shè)計(jì)【第218頁】7- 1-1#in clude int mai n()int hcf(i nt,i nt);int lcd(i nt,i nt,i nt);int u,v,h,l;sca nf(%d,%d,&u,&v); h=hcf(u,v);prin tf(H.C.F=%dn,h); l=lcd(u,v,h);prin tf(L.C.D=%dn,l); return 0;int hcf(int u,i nt v)int t,r;if (vu)t=u;u=v;v=t;while (r=u%v)!=0)u=v;v=r;return(v

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論