程序設(shè)計(jì)答案壓縮_第1頁(yè)
程序設(shè)計(jì)答案壓縮_第2頁(yè)
程序設(shè)計(jì)答案壓縮_第3頁(yè)
程序設(shè)計(jì)答案壓縮_第4頁(yè)
程序設(shè)計(jì)答案壓縮_第5頁(yè)
已閱讀5頁(yè),還剩2頁(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)介

1、1. 判斷m是否為素?cái)?shù)。 int i,k=1;if(m<=1) k=0;for(i=2;i<m;i+) if(m%i=0) k=0; return k;2. 請(qǐng)編一個(gè)函數(shù)void fun(int ttMN,int ppN),tt指向一個(gè)M行N列的二維數(shù)組,求出二維數(shù)組每列中最大元素,并依次放入pp所指一維數(shù)組中。二維數(shù)組中的數(shù)已在主函數(shù)中賦予。答案: int i,j;for(j=0;j<N;j+)ppj=tt0j;for(i=1;i<M;i+)if(ttij>ppj)ppj=ttij;3. 從鍵盤上輸入任意實(shí)數(shù),求出其所對(duì)應(yīng)的函數(shù)值。z=e的x次冪(x>10

2、)z=log(x+3) (x>-3)z=sin(x)/(cos(x)+4)答案:double z;if(x>10) z=exp(x);else if(x>-3) z=log(x+3);else z=sin(x)/(cos(x)+4);return(z);4. 求給定正整數(shù)n以內(nèi)的素?cái)?shù)之積。(n<28)答案:long i,k;long s=1;for(i=2;i<=n;i+)for(k=2;k<i;k+)if(i%k=0)break;if(k=i)s=s*i;return s;5. 計(jì)算并輸出給定整數(shù)的所有因子之積(包括自身)。規(guī)定這個(gè)整數(shù)的值不大于50。答案

3、: long s=1,i;for(i=2;i<=n;i+)if(n%i=0)s=s*i;return s;6. 產(chǎn)生20個(gè)30,120上的隨機(jī)整數(shù)放入二維數(shù)組a54中, 求其中的最小值。答案: int i,j,s;s=a00;for(i=0;i<5;i+)for(j=0;j<4;j+)if(s>aij)s=aij;return(s);7. 編寫函數(shù)判斷一個(gè)整數(shù)能否同時(shí)被3和5整除,若能則返回值為1,否則為0。調(diào)用該函數(shù)求出15300之間能同時(shí)被3和5整除的數(shù)的個(gè)數(shù)。答案: if(n%3=0&&n%5=0) return(1);return(0);8. 編

4、寫函數(shù)fun求1!+2!+3!+ +n!的和,在main函數(shù)中由鍵盤輸入n值,并輸出運(yùn)算結(jié)果。請(qǐng)編寫fun函數(shù)。例如:若n值為5,則結(jié)果為153。答案: int i;float f=1,s=0;for(i=1;i<=n;i+)f=f*i;s=s+f; return s;9. 對(duì)某一正數(shù)的值保留2位小數(shù),并對(duì)第三位進(jìn)行四舍五入。答案: int i;i=(int)(h*1000)%10;if(i>=5)return(int)(h*100+1)/100.0;elsereturn(int)(h*100)/100.0;10. 能計(jì)算從1開始到n的自然數(shù)的和,n由鍵盤輸入,并在main()函數(shù)

5、中輸出。答案:int sum,i;sum =0;for(i=1;i<=n;i+)sum=sum+i;return(sum);11. 求出二維數(shù)組周邊元素之和,作為函數(shù)值返回。二維數(shù)組的值在主函數(shù)中賦予。答案: int s=0;int i,j;for(i=0;i<M;i+)s=s+ai0+aiN-1;for(j=1;j<N-1;j+) s=s+a0j+aM-1j; return s;12. 功能求一個(gè)四位數(shù)的各位數(shù)字的立方和。答案int d,s=0;while (n>0)d=n%10;s+=d*d*d;n/=10;return s;13. 對(duì)長(zhǎng)度為8個(gè)字符的字符串,將8個(gè)

6、字符按降序排列。例如:原來(lái)的字符串為CEAedcab,排序后輸出為edcbaECA。答案: int i,j;char t;for(i=0;i<num;i+)for(j=i+1;j<num;j+)if(si<sj) t=si;si=sj;sj=t;14. 編寫函數(shù)fun計(jì)算下列分段函數(shù)的值: x2+x+6 x<0且x-3 f(x)= x2-5x+6 0x<10且x2及x3 x2-x-1 其它答案: float y;if (x<0 && x!=-3.0)y=x*x+x+6;else if(x>=0 && x<10.0

7、&& x!=2.0 && x!=3.0)y=x*x-5*x+6;else y=x*x-x-1;return y; 15. 求n階方陣主、副對(duì)角線上的元素之積。答案: int i,j;float t=1;for(i=0;i<N;i+)for(j=0;j<N;j+)if(i=j|i+j=N-1)t=t*arrij;return(t);16. 從字符串s中刪除指定的字符c。答案:int i,k=0;for(i=0;si!='0'i+)if(si!=c) sk+=si;sk='0'17. 對(duì)任意輸入的 x,用下式計(jì)算并輸出 y

8、 的值。 5 x<10 y= 0 x=10 -5 x>10答案:int m;if(n<10)m=5;else if(n=10) m=0;else m=-5;return m;18. 編寫函數(shù)用冒泡排序法對(duì)數(shù)組中的數(shù)據(jù)進(jìn)行從小到大的排序。答案: int i,j,t; for(i=0;i<n-1;i+)for(j=0;j<n-1-i;j+)if(aj>aj+1) t=aj;aj=aj+1;aj+1=t;19. 把20個(gè)隨機(jī)數(shù)存入一個(gè)數(shù)組,然后輸出該數(shù)組中的最大值。 答案: int i,max=0; for(i=1; i <size; i+)if(listm

9、ax<listi) max=i; return max;20. 把20個(gè)隨機(jī)數(shù)存入一個(gè)數(shù)組,然后輸出該數(shù)組中的最小值。其中確定最小值的下標(biāo)的操作在fun函數(shù)中實(shí)現(xiàn),請(qǐng)給出該函數(shù)的定義。答案: int i,min=0; for(i=1; i <size; i+)if(listmin>listi) min=i; return min;21. 給定n個(gè)數(shù)據(jù), 求最小值出現(xiàn)的位置(如果最小值出現(xiàn)多次,求出第一次出現(xiàn)的位置即可)。答案: int i,k; k=0; for(i=1;i<n;i+)if(si<sk) k=i; return(k);22. 求1到100之間的偶數(shù)

10、之積。答案:double y=1;int i;for(i=1;i<=m;i+)if(i%2=0)y*=i;return y;23. 求一組數(shù)中大于平均值的數(shù)的個(gè)數(shù)。例如:給定的一組數(shù)為1,3,6,9,4,23,35,67,12,88時(shí),函數(shù)值為3。答案: int i,k=0; float s=0,ave;for(i=0;i<n;i+)s+=ai;ave=s/n;printf("%f ",ave);for(i=0;i<n;i+)if(ai>ave)k+;eturn k;24·判斷一個(gè)整數(shù)w的各位數(shù)字平方之和能否被5整除,可以被5整除則返回1,

11、否則返回0。答案: int k,s=0; dos=s+(w%10)*(w%10);w=w/10;while(w!=0); if(s%5=0)k=1;else k=0;return(k);25. 找出一批正整數(shù)中的最大的偶數(shù)。答案: int i,amax=-1;for(i=0;i<n;i+) if(ai%2=0)if (ai>amax) amax=ai; return amax;26. 編寫函數(shù)實(shí)現(xiàn)兩個(gè)數(shù)據(jù)的交換,在主函數(shù)中輸入任意三個(gè)數(shù)據(jù),調(diào)用函數(shù)對(duì)這三個(gè)數(shù)據(jù)從大到小排序。答案: int k; k=*a;*a=*b; *b=k;27. 輸入華氏溫度求攝氏溫度。轉(zhuǎn)換公式為 c=5/9

12、(f-32),輸出結(jié)果取兩位小數(shù)。答案: float n;n=(5.0/9.0)*(m-32); return n; 28. 能計(jì)算從1開始到n的自然數(shù)中偶數(shù)的平方的和,n由鍵盤輸入,并在main()函數(shù)中輸出。(n是偶數(shù))答案: int sum,i;sum =0;for(i=2;i<=n;i=i+2)sum=sum+i*i;return(sum);29. 編寫函數(shù)求表達(dá)式的和(n的值由主函數(shù)輸入)。1-1/2+1/3-1/4+.+1/m例如:當(dāng)n=20時(shí),表達(dá)式的值為0.668771。答案: float s=0;int i,k=1;for(i=1;i<=n;i+) s=s+k*1

13、.0/i;k=-k;return(s);30. 求大于lim(lim小于100的整數(shù))并且小于100的所有素?cái)?shù)并放在aa數(shù)組中,該函數(shù)返回所求出素?cái)?shù)的個(gè)數(shù)。答案: int n=0; int i,j; for(i=lim;i<=100;i+) for(j=2;j<i;j+)if(i%j=0) break;if(j=i) aan+=i;return n;31. 將從鍵盤上輸入的每個(gè)單詞的第一個(gè)字母轉(zhuǎn)換為大寫字母,輸入時(shí)各單詞必須用空格隔開,用.結(jié)束輸入。 答案if (*c= ' ') return 1;else if(status && *c <=

14、 'z' && *c >= 'a')*c += 'A' - 'a'return 0;32.用while語(yǔ)句求1100的累計(jì)和。答案: int i=1,sum=0;while(i<=n) sum=sum+i; i+;return sum;33. 從字符串中刪除指定的字符。同一字母的大、小寫按不同字符處理。例如:若程序執(zhí)行時(shí)輸入字符串為:turbocandborlandc+從鍵盤上輸入字符:n,則輸出后變?yōu)椋簍urbocadborladc+,如果輸入的字符在字符串中不存在,則字符串照原樣輸出。 答案: ch

15、ar *q=s; for(; *q; q+) if(*q != c) *(s+)=*q;*s=0;34. 從鍵盤上輸入任意實(shí)數(shù)x,求出其所對(duì)應(yīng)的函數(shù)值。 z=(x-4)的二次冪(x>4) z=x的八次冪(x>-4) z=z=4/(x*(x+1)(x>-10)z=|x|+20(其他)答案: float z;if(x>4) z=sqrt(x-4); else if(x>-4) z=pow(x,8);else if(x>-10) z=4/(x*(x+1);else z=fabs(x)+20;return(z);35. 刪除所有值為y的元素。數(shù)組元素中的值和y的值由

16、主函數(shù)通過(guò)鍵盤輸入。答案: int i,j;for(i=0;i<*n;) if(bbi=y)for(j=i;j<*n;j+)bbj=bbj+1;*n=*n-1;elsei+; 36. 給定n個(gè)數(shù)據(jù), 求最大值出現(xiàn)的位置(如果最大值出現(xiàn)多次,求出第一次出現(xiàn)的位置即可)。答案: int i,k;k=0;for(i=1;i<=n;i+)if(si>sk) k=i;return(k+1);37. 從低位開始取出長(zhǎng)整型變量s奇數(shù)位上的數(shù),依次構(gòu)成一個(gè)新數(shù)放在t中。例如:當(dāng)s中的數(shù)為:7654321時(shí),t中的數(shù)為:7531。答案: long sl=10; t = s % 10;wh

17、ile(s > 0) s = s/100; t = s%10*sl + t;sl = sl * 10;38. 求給定正整數(shù)m以內(nèi)的素?cái)?shù)之和。例如:當(dāng)m=20時(shí),函數(shù)值為77。答案: int i,k,s=0;for(i=2;i<=m;i+)for(k=2;k<i;k+)if(i%k=0)break;if(k=i)s=s+i;return s;39. 將字符串中的小寫字母轉(zhuǎn)換為對(duì)應(yīng)的大寫字母,其它字符不變。答案: int i;for(i=0;stri!='0'i+)if(stri>='a' && stri<='z

18、') stri=stri-32;40. 統(tǒng)計(jì)出若干個(gè)學(xué)生的平均成績(jī),最高分以及得最高分的人數(shù)。例如:輸入10名學(xué)生的成績(jī)分別為92,87,68,56,92,84,67,75,92,66,則輸出平均成績(jī)?yōu)?7.9,最高分為92,得最高分的人數(shù)為3人。答案: int i;float sum=0,ave; Max=array0;for(i=0;i<n;i+) if(Max<array i) Max=array i;sum=sum+array i;ave=sum/n;for(i=0;i<n;i+)if(array i=Max) J+;return(ave);41. 求一批數(shù)中

19、小于平均值的數(shù)的個(gè)數(shù)。答案:int i,sum=0,k=0;double average;for(i=0;i<n;i+)sum=sum+ai; average=sum*1.0/n;for(i=0;i<n;i+)if(average>ai) k+;return(k);42. 從鍵盤輸入一個(gè)大寫字母,要求改用小寫字母輸出。答案:c=c+32; return c;43. 從鍵盤輸入一個(gè)大于3的整數(shù),調(diào)用函數(shù)fun判斷其是否素?cái)?shù),然后在main函數(shù)中輸出相應(yīng)的結(jié)論信息。例如:7是素?cái)?shù),8不是素?cái)?shù)。請(qǐng)編寫fun函數(shù)。素?cái)?shù)是僅能被1和自身整除的數(shù)。答案: int i;int j;j= 1

20、;for(i=2;i<n;i+)if(n%i=0) j= 0;return j;44. 求小于lim的所有素?cái)?shù)并放在aa數(shù)組中,該函數(shù)返回所求出素?cái)?shù)的個(gè)數(shù)。答案: int n=0; int i,j;for(i=2;i<=lim;i+)for(j=2;j<i;j+)if(i%j=0) break;if(j=i) aan+=i;return n;45. 求一個(gè)給定字符串中的字母的個(gè)數(shù)。答案: int i,k=0;for(i=0;si!='0'i+)if(si>='a'&&si<='z'|si>=&#

21、39;A'&&si<='Z')k+;return k;46. 將主函數(shù)中輸入的字符串反序存放。例如:輸入字符串“abcdefg”,則應(yīng)輸出“gfedcba”。 答案: int i,j; char c;for(i=0,j=n-1;i<j;i+,j-) /*或for(i=0,j=n-1;i<n/2;i+,j-)*/c=*(str+i);*(str+i)=*(str+j);*(str+j)=c;47·將兩個(gè)兩位數(shù)的正整數(shù)a、b合并形成一個(gè)整數(shù)放在c中。合并的方式是:將a數(shù)的十位和個(gè)位數(shù)依次放在c數(shù)的百位和個(gè)位上, b數(shù)的十位和個(gè)位數(shù)

22、依次放在c數(shù)的十位和千位上。例如:當(dāng)a45,b=12。調(diào)用該函數(shù)后,c=2415。 答案: *c=a/10*100+a%10+b/10*10+b%10*1000;48. 將兩個(gè)兩位數(shù)的正整數(shù)a、b合并形成一個(gè)整數(shù)放在c中。合并的方式是: 將a數(shù)的十位和個(gè)位數(shù)依次放在c數(shù)的個(gè)位和百位上, b數(shù)的十位和個(gè)位數(shù)依次放在c數(shù)的十位和千位上。例如: 當(dāng)a=45,b=12, 調(diào)用該函數(shù)后, c=2514。答案: *c=a/10+a%10*100+b/10*10+b%10*1000; 49. 求一個(gè)大于10的n位整數(shù)的后n-1位的數(shù),并作為函數(shù)值返回。答案: int n=0;int i=1;while(w&

23、gt;10)n=n+i*(w%10);w/=10;i*=10;return n;50. 求一個(gè)n位自然數(shù)的各位數(shù)字的積。(n 是小于10的自然數(shù))答案: long d,s=1; while (n>0)d=n%10;s*=d;n/=10;return s;51. 編寫main程序調(diào)用函數(shù)fact求解從m個(gè)元素選n個(gè)元素的組合數(shù)的個(gè)數(shù)。計(jì)算公式是:組合數(shù)m!/(n!.(m-n)!)。要求:m不能小于n,否則應(yīng)有容錯(cuò)處理。說(shuō)明:函數(shù)fact(x)的功能是求x!。答案: while(m<n) printf("m和n輸入錯(cuò)!請(qǐng)重新輸入:n");scanf("%d

24、%d",&m,&n);zhsgs=fact(m)/(fact(n)*fact(m-n);52.求出菲波那契數(shù)列的前一項(xiàng)與后一項(xiàng)之比的極限的近似值。例如:當(dāng)誤差為0.0001時(shí),函數(shù)值為0.618056。答案:float f1=1,f2=1,f3;float r1=2,r2;dor2=r1;r1=f1/f2;f3=f1+f2;f1=f2;f2=f3;while(fabs(r1-r2)>1e-4);return r1;53. 調(diào)用函數(shù)fun判斷一個(gè)三位數(shù)是否"水仙花數(shù)"。在main函數(shù)中從鍵盤輸入一個(gè)三位數(shù),并輸出判斷結(jié)果。請(qǐng)編寫fun函數(shù)。說(shuō)明

25、:所謂"水仙花數(shù)"是指一3位數(shù),其各位數(shù)字立方和等于該數(shù)本身。例如:153是一個(gè)水仙花數(shù),因?yàn)?53=1+125+27。答案: int bw,sw,gw;bw=n/100;sw=(n-bw*100)/10;gw=n%10;if(n=bw*bw*bw+sw*sw*sw+gw*gw*gw) return 1;else return 0;54. 在鍵盤上輸入一個(gè)3行3列矩陣的各個(gè)元素的值(值為整數(shù)),然后輸出矩陣第一行與第三行元素之和,并在fun()函數(shù)中輸出。答案: int sum;int i,j;sum=0;for(i=0;i<3;i+=2)for(j=0;j<3

26、;j+)sum=sum+aij;return sum;55. 分別統(tǒng)計(jì)字符串中字母、數(shù)字、空格和其他字符出現(xiàn)的次數(shù)(字符長(zhǎng)度小于80)。答案:int i;for(i=0;ci!='0'i+) if(ci>='A'&&ci<='Z')|(ci>='a'&&ci<='z') a=a+1; else if (ci>='0'&&ci<='9') num=num+1;else if (ci=' '

27、;) b=b+1; else other=other+1;56. 編寫一個(gè)函數(shù),該函數(shù)可以統(tǒng)計(jì)一個(gè)長(zhǎng)度為2的字符串在另一個(gè)字符串中出現(xiàn)的次數(shù)。例如:假定輸入的字符串為:asdasasdfgasdaszx67asdmklo,字符串為:as,則應(yīng)輸出6。答案: int i,n=0;for(i=0;i<=strlen(str)-2;i+)if(stri=substr0)&&(stri+1=substr1)n+; return n;57. 對(duì)長(zhǎng)度為7個(gè)字符的字符串,除首、尾字符外,將其余5個(gè)字符按降序排列。例如:原來(lái)的字符串為CEAedca,排序后輸出為CedcEAa。答案:-

28、int i,j; char t; for(i=1;i<num-1;i+) for(j=i+1;j<num-1;j+) if(si<sj) t=si;si=sj;sj=t;58. 編寫函數(shù)fun,求任一整數(shù)m的n次方。答案:long int x=1;int i;for(i=1;i<=n;i+)x=x*m;return x;59. 編寫函數(shù)fun其功能是:根據(jù)整型形參m,計(jì)算如下公式的值:y=11/31/51/71/(2m+1)例如:若m=9,則應(yīng)輸出:2.133256答案:double y=1;int i;for(i=1; i<=m; i+)y+=1.0/(2*i+

29、1); return(y);60. 編寫函數(shù)用選擇排序法對(duì)數(shù)組中的數(shù)據(jù)進(jìn)行從小到大的排序。答案:int i,j,k,t;for(i=0;i<n-1;i+)k=i;for(j=i+1;j<n;j+)if(ak>aj) k=j;if(k!=i) t=ai;ai=ak;ak=t;61. 求一分?jǐn)?shù)序列2/1,3/2,5/3,8/5,13/8,21/13的前n項(xiàng)之和。說(shuō)明:每一分?jǐn)?shù)的分母是前兩項(xiàng)的分母之和,每一分?jǐn)?shù)的分子是前兩項(xiàng)的分子之和例如:求前20項(xiàng)之和的值為32.660259。答案: int i;float f1=1,f2=1,f3,s=0;for(i=1;i<=n;i+)

30、f3=f1+f2;f1=f2;f2=f3;s=s+f2/f1;return s;62. 從低位開始取出長(zhǎng)整型變量s中偶數(shù)位上的數(shù),依次構(gòu)成一個(gè)新數(shù)放在t中。 例如:當(dāng)s中的數(shù)為:7654321時(shí),t中的數(shù)為:642。答案: long sl=10;s /= 10; t = s % 10;while(s > 0) s = s/100 t = s%10*sl + t;sl = sl * 10;63. 編寫函數(shù)fun將一個(gè)數(shù)組中的值按逆序存放,并在main()函數(shù)中輸出。例如:原來(lái)存順序?yàn)?,6,5,4,1。要求改為:1,4,5,6,8。答案: int i,t;for(i=0;i<n/2;

31、i+) t=arri;arri=arrn-1-i;arrn-1-i=t;64. 編寫函數(shù)fun求一個(gè)字符串的長(zhǎng)度,在main函數(shù)中輸入字符串,并輸出其長(zhǎng)度。答案:char *p;int n=0;p=p1;while(*p+)n+;return n;65. 判斷整數(shù)x是否是同構(gòu)數(shù)。若是同構(gòu)數(shù),函數(shù)返回1;否則返回0。x的值由主函數(shù)從鍵盤讀入,要求不大于100。說(shuō)明:所謂“同構(gòu)數(shù)”是指這樣的數(shù),這個(gè)數(shù)出現(xiàn)在它的平方數(shù)的右邊。例如:輸入整數(shù)5,5的平方數(shù)是25,5是25中右側(cè)的數(shù),所以5是同構(gòu)數(shù)。答案: int k;k=x*x;if(k%10=x)|(k%100=x)return 1;elseret

32、urn 0;66. 找出一個(gè)大于給定整數(shù)且緊隨這個(gè)整數(shù)的素?cái)?shù),并作為函數(shù)值返回。答案: int i,k;for(i=n+1;i+)for(k=2;k<i;k+)if(i%k=0)break;if(k=i)return(i);67. 求出N×M整型數(shù)組的最大元素及其所在的行坐標(biāo)及列坐標(biāo)(如果最大元素不唯一,選擇位置在最前面的一個(gè))。例如:輸入的數(shù)組為: 1 2 3 4 15 6 12 18 9 10 11 2求出的最大數(shù)為18,行坐標(biāo)為2,列坐標(biāo)為1。答案: int max,i,j;max=array 00;Row=0;Col=0;for(i=0;i<N;i+)for(j=

33、0;j<M;j+)if(max<array ij)max=array ij;Row=i;Col=j;return(max);68. 編寫程序,實(shí)現(xiàn)矩陣(3行3列)的轉(zhuǎn)置(即行列互換) 例如:輸入下面的矩陣: 100 200 300 400 500 600 700 800 900 程序輸出: 100 400 700 200 500 800 300 600 900 答案: int i,j,t; for(i=0; i < 3; i+) for(j=0; j < i; j+) t=arrayij; arrayij=arrayji;arrayji=t; 69. 求一批數(shù)中最大值和

34、最小值的積。答案: int i,max,min;max=min=a0;for(i=1;i<n;i+)if(ai>max) max=ai;else if(ai<min) min=ai;return(max*min);70. 編寫函數(shù)fun求sum=d+dd+ddd+dd.d(n個(gè)d),其中d為1-9的數(shù)字。例如:3+33+333+3333+33333(此時(shí)d=3,n=5),d和n在主函數(shù)中輸入。答案: long int s=0,t=0;int i;for(i=1;i<=n;i+) t=t+d;s=s+t;d=d*10;return s;71. 計(jì)算n門課程的平均值,計(jì)算結(jié)

35、果作為函數(shù)值返回。例如:若有5門課程的成績(jī)是:92,76,69,58,88,則函數(shù)的值為76.600000。答案:int i;float y=0;for(i=0;i<n;i+)y+=ai;y=y/n;return y;72 :編寫函數(shù)求3!+6!+9!+12!+15+18!+21!。答案: int i,j;float t,s=0;for(i=3;i<=n;i=i+3)t=1;for(j=1;j<=i;j+)t=t*j;s=s+t; return(s);73. 編寫函數(shù)fun(str,i,n),從字符串str中刪除第i個(gè)字符開始的連續(xù)n個(gè)字符(注意:str0代表字符串的第一個(gè)字

36、符)。答案:while(stri+n-1)stri-1=stri+n-1;i+;stri-1='0'74. 求1到w之間的奇數(shù)之和。(w是大于等于100小于等于1000的整數(shù))答案: long y=0;int i;for(i=1;i<=w;i+)if(i%2=1)y+=i;return y;75. 編寫程序打印如圖1所示圖形。 * * * * * *要求:要求使用abs()。答案: for(m=-i;m<=i;m+) for(n=0;n<abs(m);n+) printf(" "); for(n=0;n<7-2*abs(m);n+)

37、printf("*"); printf("n"); 76. 求5行5列矩陣的主、副對(duì)角線上元素之和。注意,兩條對(duì)角線相交的元素只加一次。例如:主函數(shù)中給出的矩陣的兩條對(duì)角線的和為45。答案:int s=0;int i,j;for(i=0;i<M;i+)s=s+aii+aiM-1-i;s=s-a(M-1)/2(M-1)/2;return s;77 求一批數(shù)中最大值和最小值的差。答案: int i,max,min;max=min=a0;for(i=1;i<n;i+) if(ai>max) max=ai; else if(ai<min)

38、 min=ai;return(max-min);78 編寫程序, 求矩陣(3行3列)與2的乘積 例如:輸入下面的矩陣: 100 200 300 400 500 600 700 800 900 程序輸出: 200 400 600 800 1000 1200 1400 1600 1800 答案: int i,j;for(i=0; i < 3; i+) for(j=0; j < 3; j+) arrayij=arrayij*2; 79. 用函數(shù)求fibonacci數(shù)列前n項(xiàng)的和。說(shuō)明:fibonacci數(shù)列為數(shù)列的第一項(xiàng)值為1,第二項(xiàng)值也為1,從第三項(xiàng)開始,每一項(xiàng)均為其前面相鄰兩項(xiàng)的和。

39、例如:當(dāng)n=28時(shí),運(yùn)行結(jié)果:832039答案: long f,k=f1+f2;int i;for(i=3;i<=28;i+)f=f1+f2; k=k+f;f1=f2;f2=f; return(k);80 在鍵盤上輸入一個(gè)3行3列矩陣的各個(gè)元素的值(值為整數(shù)),然后輸出主對(duì)角線元素的積,并在fun() 函數(shù)中輸出。答案: int sum;int i,j;sum=1;for(i=0;i<3;i+)sum=sum*aii;return sum;81. 輸入一個(gè)字符串,過(guò)濾此串,只保留串中的字母字符,并統(tǒng)計(jì)新生成串中包含的字母?jìng)€(gè)數(shù)。例如:輸入的字符串為ab234$df4,新生成的串為ab

40、df 。答案: int i,j;for(i=0,j=0;*(ptr+i)!='0'i+)if(*(ptr+i)<='z'&& *(ptr+i)>='a'|*(ptr+i)<='Z' && *(ptr+i)>='A')*(ptr+j)=*(ptr+i);j+;*(ptr+j)='0'return(j);82. 根據(jù)整型形參m,計(jì)算如下公式的值:y=1/5+1/61/71/81/9+1/10.1/(m+5)。例如:若m=9,則應(yīng)輸出:1.16822

41、9答案:double y=0;int i;for(i=0; i<=m; i+) y+=1.0/(i+5); return(y);83:編寫程序求無(wú)理數(shù)e的值并輸出。計(jì)算公式為:e=1+1/1!+1/2!+1/3!+.+1/n!當(dāng)1/n!<0.000001時(shí)e=2.718282。答案: long int j;int i,k; double e,jc;i=1;e=0.0;jc=1.0;while(jc>=0.000001) e=e+jc;j=1;for(k=1;k<=i;k+)j=j*k;jc=1.0/j;i+; return e;84 實(shí)現(xiàn)兩個(gè)整數(shù)的交換。例如:給a和b分

42、別輸入:60和65,輸入為:a=65 b=60答案: int t;t=*a;*a=*b;*b=t;85. 用函數(shù)求N個(gè)10,60上的整數(shù)中能被5整除的最大的數(shù),如存在則返回這個(gè)最大值,如果不存在則返回0。答案: int i; for(i=0;i<n;i+)if(arri%5=0 && arri>m)m=arri;86. 輸入2個(gè)學(xué)生3門課的成績(jī),計(jì)算學(xué)生成績(jī)平均分,課程平均分和最高分. 例如:輸入2名學(xué)生3門課的成績(jī)分別為92,87,68,56, 92,84 則學(xué)生1平均分:82.33學(xué)生2平均分:77.33課程1平均分:74.00課程2平均分:89.50課程3平均

43、分:76.00最高分為:92答案:int i,j;float sum;for(i=0;i<2;i+) /*計(jì)算第i個(gè)學(xué)生平均分*/um=0;for(j=0;j<3;j+)sum=sum+scoreij;StuAgvi=sum/3;for(j=0;j<3;j+) /*計(jì)算第j門課的平均分*/sum=0;for(i=0;i<2;i+)sum=sum+ score ij;CouAgvj=sum/2;Max=score00;for(i=0;i<2;i+)for(j=0;j<3;j+)if(Max<=scoreij)Max=scoreij;return ;87

44、用函數(shù)求一個(gè)N階方陣右下三角元素的和(包括副對(duì)角線上的元素)。答案: int i,j,k=0;for(i=0;i<N;i+)for(j=N-1-i;j<N;j+)k=k+aij;return(k);88. 編寫函數(shù)判斷一個(gè)整數(shù)m的各位數(shù)字之和能否被7整除,可以被7整除則返回1,否則返回0。調(diào)用該函數(shù)找出100200之間滿足條件的所有數(shù)。答案: int k,s=0; dos=s+m%10;m=m/10;while(m!=0);if(s%7=0)k=1;else k=0; return(k);89. 根據(jù)整型參數(shù)n,計(jì)算如圖公式的值答案: double a=1;int i;for(i=1;i<n;i+)a=1.0/(1+a);return a;90. 若x、y為奇數(shù),求x到y(tǒng)之間的奇數(shù)和;

溫馨提示

  • 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)論