C語(yǔ)言程序設(shè)計(jì)習(xí)題3.doc_第1頁(yè)
C語(yǔ)言程序設(shè)計(jì)習(xí)題3.doc_第2頁(yè)
C語(yǔ)言程序設(shè)計(jì)習(xí)題3.doc_第3頁(yè)
C語(yǔ)言程序設(shè)計(jì)習(xí)題3.doc_第4頁(yè)
C語(yǔ)言程序設(shè)計(jì)習(xí)題3.doc_第5頁(yè)
已閱讀5頁(yè),還剩16頁(yè)未讀 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡(jiǎn)介

習(xí)題3參考解答1.什么是算法?常用描述算法的工具有哪些?解:所謂算法,就是計(jì)算機(jī)解決某一個(gè)問(wèn)題的具體方法和步驟。常用描述算法的工具有流程圖、N-S圖。2.試用流程圖表示求3個(gè)數(shù)中的最大數(shù)的算法。解:流程圖如圖1-1所示。圖1-1 求3個(gè)數(shù)中的最大數(shù)的流程圖3.什么是結(jié)構(gòu)化程序設(shè)計(jì)?它的主要內(nèi)容是什么?解:結(jié)構(gòu)化程序設(shè)計(jì)(structured programming)是進(jìn)行以模塊功能和處理過(guò)程設(shè)計(jì)為主的詳細(xì)設(shè)計(jì)的基本原則。它的主要觀點(diǎn)是采用自頂向下、逐步求精的程序設(shè)計(jì)方法;使用3種基本控制結(jié)構(gòu)構(gòu)造程序,任何程序都可由順序、選擇、循環(huán)這3種基本控制結(jié)構(gòu)構(gòu)造 。4.從鍵盤(pán)輸入3個(gè)整數(shù),按照從小到大的順序輸出。解:#includeint main()int a,b,c,temp; scanf(%d,%d,%d,&a,&b,&c); if(ab)temp=a;a=b;b=temp; if(ac)temp=a;a=c;c=temp; if(bc)temp=b;b=c;c=temp; printf(%d,%d,%dn,a,b,c); return 0;程序運(yùn)行情況如下:12,8,298,12,295.輸入一個(gè)華氏溫度F,要求輸出攝氏溫度C。公式為 要求要有文字說(shuō)明,取兩位小數(shù)。解:#includeint main()float f,c; printf(請(qǐng)輸入一個(gè)華氏溫度:n); scanf(%f,&f); c=5*(f-32)/9; printf(%.2fn,c); return 0;程序運(yùn)行情況如下:請(qǐng)輸入一個(gè)華氏溫度:362.226輸入一個(gè)三位整數(shù),要求輸出它的百位數(shù)、十位數(shù)和個(gè)位數(shù)。解:#includeint main()int num; /* num表示一個(gè)三位整數(shù) */ int a,b,c; /* a,b,c分別表示百位、十位和個(gè)位上的數(shù)字 */ scanf(%d,&num); a=num/100; b=(num-a*100)/10; c=num-a*100-b*10; printf(%d,%d,%dn,a,b,c); return 0;程序運(yùn)行情況如下:1231,2,37小紅有面值1分的硬幣638枚,可以兌換成幾元幾角剩余幾分?說(shuō)明:100枚1分的硬幣可以兌換成1元,10枚1分的硬幣可以兌換成1角。兌換原則是面額從大到小。解:#includeint main()int a=638; int yuan;int jiao;int fen,temp;yuan=a/100;temp=a%100;jiao=temp/10;fen=temp%10;printf(1元的數(shù)量:%dn,yuan); printf(1角的數(shù)量:%dn,jiao); printf(1分的數(shù)量:%dn,fen);return 0;程序運(yùn)行結(jié)果如下:1元的數(shù)量:61角的數(shù)量:31分的數(shù)量:88設(shè)圓柱的半徑為2.5,圓柱的高為4,求圓柱的體積。用scanf函數(shù)輸入數(shù)據(jù),printf函數(shù)輸出計(jì)算結(jié)果,輸出時(shí)要求有文字說(shuō)明,取兩位小數(shù)。解: #include #define PI 3.1415926 int main()float r,h,v;printf(Please input r,h:);scanf(%f,%f,&r,&h);v=PI*r*r*h;printf(半徑為:%.2f,高為:%.2f的圓柱體體積為:%.2fn,r,h,v);return 0;程序運(yùn)行情況如下:Please input r,h:2.5,4半徑為:2.50,高為:4.00的圓柱體體積為:78.549輸入三角形的三邊,計(jì)算三角形的面積。要求:對(duì)輸入的3個(gè)邊長(zhǎng)進(jìn)行判斷,如果能構(gòu)成三角形,則計(jì)算三角形的面積;否則,則顯示“構(gòu)不成三角形!”信息。解:#include#includeint main()int a,b,c;float s,area;scanf(%d,%d,%d,&a,&b,&c);if(a+bc & a+cb &b+ca)s=(float)(a+b+c)/2; area=sqrt(s*(s-a)*(s-b)*(s-c); printf(面積為:%.2fn,area);elseprintf(邊長(zhǎng)分別為%d、%d、%d的三邊構(gòu)不成三角形!n,a,b,c);return 0;程序運(yùn)行情況如下:3,4,6面積為:5.333,6,12邊長(zhǎng)分別為3、6、12的三邊構(gòu)不成三角形!10設(shè)計(jì)一個(gè)C語(yǔ)言程序,求5個(gè)數(shù)中的最大數(shù)和最小數(shù)。解:#includeint main()int a,b,c,d,e,max,min;scanf(%d%d%d%d%d,&a,&b,&c,&d,&e);max=min=a;if(bmax) max=b;if(bmax) max=c;if(cmax) max=d;if(dmax) max=e;if(emin) min=e;printf(max:%d,min:%dn,max,min);return 0;程序運(yùn)行情況如下:2 5 6 8 9max:9,min:211判斷輸入的字符屬于哪一類字符:大寫(xiě)字母、小寫(xiě)字母、數(shù)字還是其他字符。解:#includeint main()char ch;scanf(%c,&ch); if(ch=48 &ch=65&ch=97&ch=122) printf(該字符為小寫(xiě)字母!); else printf(該字符為其他字符!);return 0;程序運(yùn)行情況如下:2該字符為數(shù)字! 12用if語(yǔ)句和switch語(yǔ)句分別編寫(xiě)程序,實(shí)現(xiàn)以下功能:從鍵盤(pán)輸入數(shù)字1,2,3,4,分別顯示Excellent,Good,Pass,F(xiàn)ail。輸入其他字符時(shí)顯示Error。解:/*用if語(yǔ)句編寫(xiě)程序*/#includeint main() char ch; scanf(%c,&ch); if(ch=1) printf(Excellentn); else if (ch=2) printf(Goodn); else if (ch=3) printf(Passn); else if (ch=4) printf(Failn); else printf(Errorn); return 0;程序運(yùn)行情況如下:1Excellent/*用switch語(yǔ)句編寫(xiě)程序*/#includeint main() char ch;scanf(%c,&ch);switch(ch) case 1:printf(Excellentn);break; case 2:printf(Goodn);break; case 3:printf(Passn);break; case 4:printf(Failn);break; default:printf(Errorn);程序運(yùn)行情況如下:1Excellent13假設(shè)國(guó)家對(duì)個(gè)人收入所得稅是按這樣的標(biāo)準(zhǔn)進(jìn)行的:起征點(diǎn)是2 000元,2 0003 000元為5%,3 0005 000元為15%,5 00010 000元為20%,10 000元以上為30%。編程輸入工資,計(jì)算實(shí)際工資所得及稅金。解:#includeint main()int gz;float sj;scanf(%d,&gz);if(gz2000)printf(不需要納稅!n);return ;else if(gz3000)sj=gz*0.05;else if(gz5000) sj=gz*0.15;else if(gz0時(shí),有兩個(gè)不等的實(shí)根;當(dāng)b2-4ac=0時(shí),有兩個(gè)相等的實(shí)根;當(dāng)b2-4ac0時(shí),有兩個(gè)虛根。解:#include#includeint main()int a,b,c;double delt,x1,x2;scanf(%d%d%d,&a,&b,&c); delt=b*b-4*a*c; if (delt=0)printf(該方程有兩個(gè)相等的實(shí)根!);x1=x2=-(double)b/(2*a);printf(%.2f,%.2fn,x1,x2);else if(delt=0)x1=(-b+sqrt(delt)/(2*a); x2=(-b-sqrt(delt)/(2*a); printf(%.2f,%.2fn,x1,x2);elseprintf(該方程無(wú)實(shí)根!n);程序運(yùn)行情況如下:3 4 5該方程無(wú)實(shí)根!4 6 2-0.50,-1.004 4 1該方程有兩個(gè)相等的實(shí)根!-0.50,-0.5015從1100中找出能被5或7整除的數(shù)。解:#includeint main() int i; for(i=1;i=100;i+) if(i%5=0|i%7=0) printf(%5d,i); return 0; 程序運(yùn)行結(jié)果如下:5 57 10 14 15 20 21 25 28 30 35 40 42 45 49 50 55 56 60 63 65 70 75 77 80 84 85 90 91 95 98 10016計(jì)算sum=1+11+111+1111+11111。解:#includeint main()int i,t=0,s=0; for(i=1;i=5;i+) t=t*10+1; printf(%dn,t); s=s+t; printf(%d,s);return 0;程序運(yùn)行結(jié)果如下:1111111111111111234517輸入兩個(gè)正整數(shù)m和n,求出它們的最大公約數(shù)和最小公倍數(shù)。解:#includeint main()int m,n,t,gcd,gcm;int a,b;scanf(%d%d,&m,&n); t=m%n;a=m;b=n;while(t!=0)m=n;n=t; t=m%n;gcd=n;gcm=a*b/gcd;printf(%d和%d的最大公約數(shù)為:%d,最小公倍數(shù)為:%dn,a,b,gcd,gcm);return 0;程序運(yùn)行情況如下:25 1525和15的最大公約數(shù)為:5,最小公倍數(shù)為:7518輸入一行字符,分別統(tǒng)計(jì)出其中英文字母、空格、數(shù)字和其他字符的個(gè)數(shù)。解:#includeint main()char ch;int m=0; int k=0; int n=0; int t=0;ch=getchar();while(ch!=n)if(ch=32) k+; else if(ch=48& ch=65& ch=97& ch=122) m+; else t+; ch=getchar(); printf(字母的個(gè)數(shù)為:%dn,m); printf(空格的個(gè)數(shù)為:%dn,k);printf(數(shù)字的個(gè)數(shù)為:%dn,n); printf(其他字符的個(gè)數(shù)為:%dn,t); return 0;程序運(yùn)行情況如下:123abcdefghyyyy;11166 #%字母的個(gè)數(shù)為:12空格的個(gè)數(shù)為:2數(shù)字的個(gè)數(shù)為:8其他字符的個(gè)數(shù)為:1119從鍵盤(pán)輸入10個(gè)學(xué)生的成績(jī),試統(tǒng)計(jì)出他們的成績(jī)總和及平均值。解:#includeint main()float cj,sum=0,aver; int i;for(i=1;i=10;i+)scanf(%f,&cj);sum=sum+cj;aver=sum/10;printf(sum=%.2f,aver=%.2f,sum,aver);return 0;程序運(yùn)行情況如下:68 75 74 56 78 75 81 76 75 85sum=743.00,aver=74.3020猴子吃桃問(wèn)題。猴子第一天摘下了若干桃子,當(dāng)即吃了一半,還不過(guò)癮,又多吃了一個(gè)。第二天早上又將剩下的桃子吃掉一半,又多吃了一個(gè)。以后每天早上都吃了前一天剩下的一半零一個(gè)。到第4天早上想要再吃時(shí),只剩下一個(gè)桃子了。求第一天猴子共摘了多少桃子。解:#includeint main()int n=1; int i; for(i=9;i=1;i-) n=2*(n+1); printf(%dn,n); return 0;程序運(yùn)行結(jié)果如下:410224694190382766153421打印出所有的“水仙花數(shù)”。所謂“水仙花數(shù)”是指一個(gè)三位數(shù),其各位數(shù)字立方和等于該數(shù)本身。例如,153就是一個(gè)水仙花數(shù),因?yàn)?53=13+53+33解:#includeint main()int i,bw,sw,gw; printf(水仙花數(shù)是:);for(i=100;i999;i+)bw=i/100;sw=(i-bw*100)/10;gw=i-bw*100-sw*10; if(i=bw*bw*bw+sw*sw*sw+gw*gw*gw)printf(%5d,i);printf(n);return 0;程序運(yùn)行結(jié)果如下:水仙花數(shù)是: 153 370 371 40722用泰勒級(jí)數(shù)求e的近似值,直到最后一項(xiàng)小于10-6為止。 e=1+1/1!+1/2!+1/3!+1/n!解: #includeint main() int i=1;long f=1;double t=1,e=1;while(t=1e-6) e=e+t;i=i+1;f=f*i;t=(double)1/f; printf(%.3lfn,e); return 0;程序運(yùn)行結(jié)果如下:2.71823輸入一個(gè)整數(shù),分解各位數(shù)字。例如,輸入“1298”,輸出“8-9-2-1-”。請(qǐng)編寫(xiě)一個(gè)C語(yǔ)言程序解決該問(wèn)題。解:#includeint main() int num,n1,n2;scanf(%d,&num);n2=num;while(n2!=0)n1=n2%10;n2=n2/10;printf(%d-,n1);printf(n);return 0;程序運(yùn)行情況如下:12988-9-2-1-24有一個(gè)分?jǐn)?shù)序列2/1,3/2,5/3,8/5,13/8,21/13求出這個(gè)數(shù)列的前20項(xiàng)之和。解:#includeint main() int i; float f,s=0; float f1=1; float f2=1; for(i=1;i=20;i+) f=f1+f2; f1=f2; f2=f; s=s+f2/f1; printf(分?jǐn)?shù)序列之和為:%f,s) ; return 0;程序運(yùn)行結(jié)果如下:分?jǐn)?shù)序列之和為:32.660259 25打印出以下圖案。 * * * * * * * * * * * * * * * * * * * 解:#includeint main()int i,j; for(i=1;i=4;i+) for(j

溫馨提示

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

評(píng)論

0/150

提交評(píng)論