《C語言程序設計》課后習題答案(第四版)譚浩強(共112頁)_第1頁
《C語言程序設計》課后習題答案(第四版)譚浩強(共112頁)_第2頁
《C語言程序設計》課后習題答案(第四版)譚浩強(共112頁)_第3頁
《C語言程序設計》課后習題答案(第四版)譚浩強(共112頁)_第4頁
《C語言程序設計》課后習題答案(第四版)譚浩強(共112頁)_第5頁
已閱讀5頁,還剩107頁未讀 繼續免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

1、精選優質文檔-傾情為你奉上第1章程序設計和C語言11.1什么是計算機程序11.2什么是計算機語言11.3C語言的發展及其特點31.4最簡單的C語言程序51.4.1最簡單的C語言程序舉例61.4.2C語言程序的結構101.5運行C程序的步驟與方法121.6程序設計的任務141-5 #include int main ( ) printf (*nn); printf( Very Good!nn); printf (*n); return 0;1-6#include int main()int a,b,c,max; printf(please input a,b,c:n); scanf(%d,%d,

2、%d,&a,&b,&c); max=a; if (maxb) max=b; if (maxc) max=c; printf(The largest number is %dn,max); return 0;第2章算法程序的靈魂162.1什么是算法162.2簡單的算法舉例172.3算法的特性212.4怎樣表示一個算法222.4.1用自然語言表示算法222.4.2用流程圖表示算法222.4.3三種基本結構和改進的流程圖262.4.4用NS流程圖表示算法282.4.5用偽代碼表示算法312.4.6用計算機語言表示算法322.5結構化程序設計方法34習題36第章最簡單的C程序設計順序程序設計373.1

3、順序程序設計舉例373.2數據的表現形式及其運算393.2.1常量和變量393.2.2數據類型423.2.3整型數據443.2.4字符型數據473.2.5浮點型數據493.2.6怎樣確定常量的類型513.2.7運算符和表達式523.3C語句573.3.1C語句的作用和分類573.3.2最基本的語句賦值語句593.4數據的輸入輸出653.4.1輸入輸出舉例653.4.2有關數據輸入輸出的概念673.4.3用printf函數輸出數據683.4.4用scanf函數輸入數據753.4.5字符數據的輸入輸出78習題823-1 #include #include int main()float p,r,n

4、; r=0.1; n=10; p=pow(1+r,n); printf(p=%fn,p); return 0;3-2-1#include #include 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年

5、期 p4=p*pow(1+r1,5); / 存1年期,到期后將本息存再存1年期,連續存5次 p5=p*pow(1+r0/4,4*5); / 存活期存款。活期利息每一季度結算一次 printf(p1=%fn,p1); / 輸出按第1方案得到的本息和 printf(p2=%fn,p2); / 輸出按第2方案得到的本息和 printf(p3=%fn,p3); / 輸出按第3方案得到的本息和 printf(p4=%fn,p4); / 輸出按第4方案得到的本息和 printf(p5=%fn,p5); / 輸出按第5方案得到的本息和 return 0;3-2-2#include #include int

6、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); / 存活期存款。活期利息每

7、一季度結算一次 printf(p1=%fn,p1); / 輸出按第1方案得到的本息和 printf(p2=%fn,p2); / 輸出按第2方案得到的本息和 printf(p3=%fn,p3); / 輸出按第3方案得到的本息和 printf(p4=%fn,p4); / 輸出按第4方案得到的本息和 printf(p5=%fn,p5); / 輸出按第5方案得到的本息和 return 0;3-2-3#include #include int main()float r5,r3,r2,r1,r0,p,p1,p2,p3,p4,p5; p=1000; r5=0.0585; r3=0.054; r2=0.04

8、68; 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.2fn,p1); / 輸出按第1方案得到的本息和 printf(p2=%10.2fn,p2); / 輸出按第2方案得到的

9、本息和 printf(p3=%10.2fn,p3); / 輸出按第3方案得到的本息和 printf(p4=%10.2fn,p4); / 輸出按第4方案得到的本息和 printf(p5=%10.2fn,p5); / 輸出按第5方案得到的本息和 return 0;3-3.#include #include int main()float d=,p=6000,r=0.01,m; m=log10(p/(p-d*r)/log10(1+r); printf(m=%6.2fn,m); return 0;3-4#include int main()int c1,c2; c1=197; c2=198; prin

10、tf(c1=%c,c2=%cn,c1,c2); printf(c1=%d,c2=%dn,c1,c2); return 0;3-5#include 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=%cn,a,b,x,y,c1,c2); return 0;3-6#include int main()char c1=C,c2=h,c3=i,c4=n,c5=a; c1

11、=c1+4; c2=c2+4; c3=c3+4; c4=c4+4; c5=c5+4; printf(passwor is %c%c%c%c%cn,c1,c2,c3,c4,c5); return 0;3-7#include int main ()float h,r,l,s,sq,vq,vz; float pi=3.; 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; /計算

12、圓球體積vq vz=pi*r*r*h; /計算圓柱體積vz printf(圓周長為: l=%6.2fn,l); printf(圓面積為: s=%6.2fn,s); printf(圓球表面積為: sq=%6.2fn,sq); printf(圓球體積為: v=%6.2fn,vq); printf(圓柱體積為: vz=%6.2fn,vz); return 0; 3-8-1#include int main() int c1,c2; /整型定義 printf(請輸入兩個整數c1,c2:); scanf(%d,%d,&c1,&c2); printf(按字符輸出結果:n); printf(%c,%cn,c

13、1,c2); printf(按ASCII碼輸出結果為:n); printf(%d,%dn,c1,c2); return 0;3-8-2#include int main() char c1,c2; /定義字符型變量 int i1,i2; /定義整型變量 printf(請輸入兩個字符c1,c2:); scanf(%c,%c,&c1,&c2); i1=c1; /賦值給整型變量 i2=c2; printf(按字符輸出結果:n); printf(%c,%cn,i1,i2); printf(按整數輸出結果:n); printf(%d,%dn,c1,c2); return 0;3-8-3#include

14、int main() char c1,c2; /定義為字符型 int i1,i2; /定義為整型 printf(請輸入兩個整數i1,i2:); scanf(%d,%d,&i1,&i2); c1=i1; /將整數賦值給字符變量 c2=i2; printf(按字符輸出結果:n); printf(%c,%cn,c1,c2); printf(按整數輸出結果:n); printf(%d,%dn,c1,c2); return 0;3-8#include int main()char c1,c2;printf(請輸入兩個字符c1,c2:);c1=getchar();c2=getchar();printf(用

15、putchar語句輸出結果為:);putchar(c1);putchar(c2);printf(n);printf(用printf語句輸出結果為:);printf(%c %cn,c1,c2);return 0;第4章選擇結構程序設計854.1選擇結構和條件判斷854.2用if語句實現選擇結構874.2.1用if語句處理選擇結構舉例874.2.2if語句的一般形式 894.3關系運算符和關系表達式914.3.1關系運算符及其優先次序914.3.2關系表達式924.4邏輯運算符和邏輯表達式924.4.1邏輯運算符及其優先次序934.4.2邏輯表達式944.4.3邏輯型變量964.5條件運算符和條件

16、表達式974.6選擇結構的嵌套994.7用switch語句實現多分支選擇結構1024.8選擇結構程序綜合舉例105習題1114-4-1#include int main() int a,b,c; printf(請輸入三個整數:); 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); return 0;4-4-2#include int main() int a,b,c

17、,temp,max; printf(請輸入三個整數:); scanf(%d,%d,%d,&a,&b,&c); temp=(ab)?a:b; /*將a和b中的大者存入temp中*/ max=(tempc)?temp:c; /*將a和b中的大者與c比較,取最大者*/ printf(三個整數的最大數是%dn,max); return 0;4-5-2#include #include #define M 1000int main() int i,k; printf(請輸入一個小于%d的整數i:,M); scanf(%d,&i); while (iM) printf(輸入的數不符合要求,請重新輸入一個小

18、于%d的整數i:,M); scanf(%d,&i); k=sqrt(i); printf(%d的平方根的整數部分是:%dn,i,k); return 0;4-5#include #include #define M 1000int main() int i,k; printf(請輸入一個小于%d的整數i:,M); scanf(%d,&i); if (iM) printf(輸入的數不符合要求,請重新輸入一個小于%d的整數i:,M); scanf(%d,&i); k=sqrt(i); printf(%d的平方根的整數部分是:%dn,i,k); return 0;4-6.#include int m

19、ain() int x,y; printf(輸入x:); scanf(%d,&x); if(x1) /* x1 */ y=x; printf(x=%3d, y=x=%dn ,x,y); else if(x10) /* 1=x=10 */ y=3*x-11; printf(x=%d, y=3*x-11=%dn,x,y); return 0;4-7-1#include int main() int x,y; printf(enter x:); scanf(%d,&x); y=-1; if(x!=0) if(x0) y=1; else y=0; printf(x=%d,y=%dn,x,y); ret

20、urn 0;4-7-2#include int main() int x,y; printf(please enter x:); scanf(%d,&x); y=0; if(x=0) if(x0) y=1; else y=-1; printf(x=%d,y=%dn,x,y); return 0;4-8#include int main() float score; char grade; printf(請輸入學生成績:); scanf(%f,&score); while (score100|score0)printf(n 輸入有誤,請重輸);scanf(%f,&score); switch(i

21、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,相應的等級是%cn ,score,grade);return 0;4-9#include #include int main() int num,indiv,ten,hundred,thousand,ten_thousand,place; /

22、分別代表個位,十位,百位,千位,萬位和位數 printf(請輸入一個整數(0-99999):); scanf(%d,&num); if (num9999) place=5; else if (num999) place=4; else if (num99) place=3; else if (num9) place=2; else place=1; printf(位數:%dn,place); printf(每位數字為:); ten_thousand=num/10000; thousand=(int)(num-ten_thousand*10000)/1000; hundred=(int)(num

23、-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%dn,indiv

24、,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,%d,hundred,ten,indiv); printf(n反序數字為:); printf(%d%d%dn,indiv,ten,hundred); break; case 2:printf(%d,%d,ten,indiv

25、); printf(n反序數字為:); printf(%d%dn,indiv,ten); break; case 1:printf(%d,indiv); printf(n反序數字為:); printf(%dn,indiv); break; return 0; 4-10-1#include int main() int i; double bonus,bon1,bon2,bon4,bon6,bon10; bon1=*0.1; bon2=bon1+*0.075; bon4=bon2+*0.05; bon6=bon4+*0.03; bon10=bon6+*0.015; printf(請輸入利潤i:)

26、; scanf(%d,&i); if (i=) bonus=i*0.1; else if (i=) bonus=bon1+(i-)*0.075; else if (i=) bonus=bon2+(i-)*0.05; else if (i=) bonus=bon4+(i-)*0.03; else if (i=) bonus=bon6+(i-)*0.015; else bonus=bon10+(i-)*0.01; printf(獎金是: %10.2fn,bonus); return 0; 4-10-2#include int main() int i; double bonus,bon1,bon2

27、,bon4,bon6,bon10; int branch; bon1=*0.1; bon2=bon1+*0.075; bon4=bon2+*0.05; bon6=bon4+*0.03; bon10=bon6+*0.015; printf(請輸入利潤i:); scanf(%d,&i); branch=i/; if (branch10) branch=10; switch(branch) case 0:bonus=i*0.1;break; case 1:bonus=bon1+(i-)*0.075;break; case 2: case 3: bonus=bon2+(i-)*0.05;break;

28、case 4: case 5: bonus=bon4+(i-)*0.03;break; case 6: case 7: case 8: case 9: bonus=bon6+(i-)*0.015;break; case 10: bonus=bon10+(i-)*0.01; printf(獎金是 %10.2fn,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=%dn,a,b,c,d);

29、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=b;b=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 %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(請輸入一個

30、點(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 (d11 & d21 & d31 & d41) h=0; /*判斷該點是否在塔外*/ printf(該點高度為 %dn,h); return 0; 第5章循環結構程序設計1145.1為什么需要循環控制1145.2用while語句實現循環1155.3

31、用dowhile語句實現循環1175.4用for 語句實現循環1205.5循環的嵌套1245.6幾種循環的比較1255.7改變循環執行的狀態1255.7.1用break語句提前終止循環1265.7.2用continue語句提前結束本次循環1275.7.3break語句和continue語句的區別1285.8循環程序舉例131習題1405-2#include #include / 程序中用到數學函數fabs,應包含頭文件math.nint main() int sign=1,count=0; / sign用來表示數值的符號,count用來統計循環次數 double pi=0.0,n=1.0,te

32、rm=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.8fn,pi); / 輸出的近似值 pri

33、ntf(count=%dn,count); / 輸出循環次數 return 0;5-3#include int main() int p,r,n,m,temp; printf(請輸入兩個正整數n,m:); scanf(%d,%d,&n,&m); if (nm) temp=n; n=m; m=temp; p=n*m; while(m!=0) r=n%m; n=m; m=r; printf(它們的最大公約數為:%dn,n); printf(它們的最小公約數為:%dn,p/n); return 0; 5-4#include int main() char c; int letters=0,space

34、=0,digit=0,other=0; printf(請輸入一行字符:n); while(c=getchar()!=n) if (c=a & c=A & c=0 & c=9) digit+; else other+; printf(字母數:%dn空格數:%dn數字數:%dn其它字符數:%dn,letters,space,digit,other); return 0; 5-5#include 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

35、組成數的值*/ sn=sn+tn; /*賦值后的sn為多項式前i項之和*/ a=a*10; +i; printf(a+aa+aaa+.=%dn,sn); return 0; 5-6#include 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.15en,s); return 0;5-7#include int main() int n1=100,n2=50,n3=10; double k,s1=0,s2=0,s3=0; for (k=1;k=n1;k+) /*計算

36、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.6fn,s1+s2+s3); return 0; 5-8#include int main() int i,j,k,n; printf(parcissus numbers are ); for (n=100;n1000;n+) i=n/100; j=n/10-i*10; k=n%10; if (n=i*i*i + j*j*j + k*k*k) pr

37、intf(%d ,n); printf(n); return 0; 5-9-1#define M 1000 /*定義尋找范圍*/#include 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;i1) printf(%d,%d,k1,k2); /* n1表示a至少有2個因子 */ if (n2) prin

38、tf(,%d,k3); /* n2表示至少有3個因子,故應再輸出一個因子 */ if (n3) printf(,%d,k4); /* n3表示至少有4個因子,故應再輸出一個因子 */ if (n4) printf(,%d,k5); /* 以下類似 */ if (n5) printf(,%d,k6); if (n6) printf(,%d,k7); if (n7) printf(,%d,k8); if (n8) printf(,%d,k9); if (n9) printf(,%d,k10); printf(n); return 0; 5-9-2#include int main() int m,

39、s,i; for (m=2;m1000;m+) s=0; for (i=1;im;i+) if (m%i)=0) s=s+i; if(s=m) printf(%d,its factors are ,m); for (i=1;im;i+) if (m%i=0) printf(%d ,i); printf(n); return 0; 5-10#include int main() int 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; printf(sum=%16.10fn,s); return 0;

40、 5-11#include int main() double sn=100,hn=sn/2; int n; for (n=2;n=10;n+) sn=sn+2*hn; /*第n次落地時共經過的米數*/ hn=hn/2; /*第n次反跳高度*/ printf(第10次落地時共經過%f米n,sn); printf(第10次反彈%f米n,hn); return 0; 5-12#include int main() int day,x1,x2; day=9; x2=1; while(day0) x1=(x2+1)*2; /*第1天的桃子數是第2天桃子數加1后的2倍.*/ x2=x1; day-; printf(total=%dn,x1); return 0; 5-13#include #include int main() float a,x0,x1; printf(enter a positive number:); scanf(%f,&a); x0=a/2; x1=(x0+a/

溫馨提示

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

評論

0/150

提交評論