函數(shù)練習(xí)題(C語言)帶答案_第1頁
函數(shù)練習(xí)題(C語言)帶答案_第2頁
函數(shù)練習(xí)題(C語言)帶答案_第3頁
函數(shù)練習(xí)題(C語言)帶答案_第4頁
函數(shù)練習(xí)題(C語言)帶答案_第5頁
已閱讀5頁,還剩11頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡介

1、.C語言函數(shù)練習(xí)題一、選擇題1. 一個(gè)完整的C源程序是【 】。 A)要由一個(gè)主函數(shù)或一個(gè)以上的非主函數(shù)構(gòu)成 B)由一個(gè)且僅由一個(gè)主函數(shù)和零個(gè)以上的非主函數(shù)構(gòu)成 C)要由一個(gè)主函數(shù)和一個(gè)以上的非主函數(shù)構(gòu)成D)由一個(gè)且只有一個(gè)主函數(shù)或多個(gè)非主函數(shù)構(gòu)成2. 以下關(guān)于函數(shù)的敘述中正確的是【 】。A)C語言程序?qū)脑闯绦蛑械谝粋€(gè)函數(shù)開始執(zhí)行B)可以在程序中由用戶指定任意一個(gè)函數(shù)作為主函數(shù),程序?qū)拇碎_始執(zhí)行C)C語言規(guī)定必須用main作為主函數(shù)名,程序?qū)拇碎_始執(zhí)行,在此結(jié)束D)main可作為用戶標(biāo)識(shí)符,用以定義任意一個(gè)函數(shù)3. 以下關(guān)于函數(shù)的敘述中不正確的是【 】。A)C程序是函數(shù)的集合,包括標(biāo)準(zhǔn)庫函

2、數(shù)和用戶自定義函數(shù)B)在C語言程序中,被調(diào)用的函數(shù)必須在main函數(shù)中定義C)在C語言程序中,函數(shù)的定義不能嵌套D)在C語言程序中,函數(shù)的調(diào)用可以嵌套4. 在一個(gè)C程序中,【 】。A)main函數(shù)必須出現(xiàn)在所有函數(shù)之前B)main函數(shù)可以在任何地方出現(xiàn)C)main函數(shù)必須出現(xiàn)在所有函數(shù)之后 D)main函數(shù)必須出現(xiàn)在固定位置5. 若在C語言中未說明函數(shù)的類型,則系統(tǒng)默認(rèn)該函數(shù)的數(shù)據(jù)類型是【 】A)floatB)longC)intD)double6. 以下關(guān)于函數(shù)敘述中,錯(cuò)誤的是【 】。A)函數(shù)未被調(diào)用時(shí),系統(tǒng)將不為形參分配內(nèi)存單元B)實(shí)參與形參的個(gè)數(shù)應(yīng)相等,且實(shí)參與形參的類型必須對應(yīng)一致C)當(dāng)

3、形參是變量時(shí),實(shí)參可以是常量、變量或表達(dá)式D)形參可以是常量、變量或表達(dá)式7. 若函數(shù)調(diào)用時(shí)參數(shù)為基本數(shù)據(jù)類型的變量,以下敘述正確的是【 】。A)實(shí)參與其對應(yīng)的形參共占存儲(chǔ)單元B)只有當(dāng)實(shí)參與其對應(yīng)的形參同名時(shí)才共占存儲(chǔ)單元C)實(shí)參與對應(yīng)的形參分別占用不同的存儲(chǔ)單元D)實(shí)參將數(shù)據(jù)傳遞給形參后,立即釋放原先占用的存儲(chǔ)單元9. 函數(shù)調(diào)用時(shí),當(dāng)實(shí)參和形參都是簡單變量時(shí),他們之間數(shù)據(jù)傳遞的過程是【 】。A)實(shí)參將其地址傳遞給形參,并釋放原先占用的存儲(chǔ)單元B)實(shí)參將其地址傳遞給形參,調(diào)用結(jié)束時(shí)形參再將其地址回傳給實(shí)參C)實(shí)參將其值傳遞給形參,調(diào)用結(jié)束時(shí)形參再將其值回傳給實(shí)參D)實(shí)參將其值傳遞給形參,調(diào)用

4、結(jié)束時(shí)形參并不將其值回傳給實(shí)參10. 若函數(shù)調(diào)用時(shí)的實(shí)參為變量時(shí),以下關(guān)于函數(shù)形參和實(shí)參的敘述中正確的是【 】。A)函數(shù)的實(shí)參和其對應(yīng)的形參共占同一存儲(chǔ)單元B)形參只是形式上的存在,不占用具體存儲(chǔ)單元C)同名的實(shí)參和形參占同一存儲(chǔ)單元D)函數(shù)的形參和實(shí)參分別占用不同的存儲(chǔ)單元11. 若用數(shù)組名作為函數(shù)調(diào)用的實(shí)參,則傳遞給形參的是 【 】。 A) 數(shù)組的首地址 B) 數(shù)組的第一個(gè)元素的值 C) 數(shù)組中全部元素的值 D) 數(shù)組元素的個(gè)數(shù)12. 若函數(shù)調(diào)用時(shí),用數(shù)組名作為函數(shù)的參數(shù),以下敘述中正確的是【 】。A)實(shí)參與其對應(yīng)的形參共用同一段存儲(chǔ)空間B)實(shí)參與其對應(yīng)的形參占用相同的存儲(chǔ)空間C)實(shí)參將其

5、地址傳遞給形參,同時(shí)形參也會(huì)將該地址傳遞給實(shí)參D)實(shí)參將其地址傳遞給形參,等同實(shí)現(xiàn)了參數(shù)之間的雙向值的傳遞13. 如果一個(gè)函數(shù)位于C程序文件的上部,在該函數(shù)體內(nèi)說明語句后的復(fù)合語句中定義了一個(gè)變量,則該變量【 】。A)為全局變量,在本程序文件范圍內(nèi)有效B)為局部變量,只在該函數(shù)內(nèi)有效C)為局部變量,只在該復(fù)合語句中有效D)定義無效,為非法變量14. C語言中函數(shù)返回值的類型是由【 】決定。 A)return語句中的表達(dá)式類型 B)調(diào)用函數(shù)的主調(diào)函數(shù)類型 C)調(diào)用函數(shù)時(shí)臨時(shí) D)定義函數(shù)時(shí)所指定的函數(shù)類型15. 若在一個(gè)C源程序文件中定義了一個(gè)允許其他源文件引用的實(shí)型外部變量a,則在另一文件中可

6、使用的引用說明是【 】。A)extern static float a; B)float a;C)extern auto float a;D)extern float a;16. 定義一個(gè)void型函數(shù)意味著調(diào)用該函數(shù)時(shí),函數(shù)【 】A)通過return返回一個(gè)用戶所希望的函數(shù)值B)返回一個(gè)系統(tǒng)默認(rèn)值C)沒有返回值D)返回一個(gè)不確定的值17. 若定義函數(shù)float *fun( ),則函數(shù)fun的返回值為【 】。A)一個(gè)實(shí)數(shù)B)一個(gè)指向?qū)嵭妥兞康闹羔楥)一個(gè)指向?qū)嵭秃瘮?shù)的指針D)一個(gè)實(shí)型函數(shù)的入口地址18.C語言規(guī)定,程序中各函數(shù)之間【 】。A)既允許直接遞歸調(diào)用也允許間接遞歸調(diào)用B)不允許直接遞

7、歸調(diào)用也不允許間接遞歸調(diào)用C)允許直接遞歸調(diào)用不允許間接遞歸調(diào)用D)不允許直接遞歸調(diào)用允許間接遞歸調(diào)用19. 若程序中定義函數(shù)float myadd(float a, float b) return a+b;并將其放在調(diào)用語句之后,則在調(diào)用之前應(yīng)對該函數(shù)進(jìn)行說明。以下說明中錯(cuò)誤的是【 】。A)float myadd( float a,b);B)float myadd(float b, float a);C)float myadd(float, float);D)float myadd(float a, float b);20. 關(guān)于以下fun函數(shù)的功能敘述中,正確的是【 】。int fun(c

8、har *s) char *t=s; while(*t+) ; t-; return(t-s); A) 求字符串s的長度B) 比較兩個(gè)串的大小C) 將串s復(fù)制到串t D) 求字符串s所占字節(jié)數(shù)21. 下面程序段運(yùn)行后的輸出結(jié)果是【 】 (假設(shè)程序運(yùn)行時(shí)輸入5,3回車)int a, b; void swap( ) int t; t=a; a=b; b=t; main() scanf(%d,%d, &a, &b); swap( ); printf (a=%d,b=%dn,a,b); A) a=5,b=3B) a=3,b=5C)5,3D)3,522. 以下程序運(yùn)行后的輸出結(jié)果是【 】。 fun(in

9、t a, int b) if(ab) return a; elsereturn b;main() int x=3,y=8,z=6,r; r=fun(fun(x,y),2*z); printf(%dn,r);A) 3B) 6C) 8D) 1223. 以下程序的運(yùn)行結(jié)果是【 】。void f(int a, int b) int t; t=a; a=b; b=t;main() int x=1, y=3, z=2; if(xy) f(x,y); else if(yz) f(x,z); else f(x,z); printf(%d,%d,%dn,x,y,z);A)1,2,3B) 3,1,2C) 1,3,

10、2D) 2,3,124. 以下程序運(yùn)行后的輸出結(jié)果為【 】。int *f(int *x, int *y) if(*x*y)return x; else return y;main() int a=7,b=8,*p,*q,*r; p=&a, q=&b; r=f(p,q); printf(%d,%d,%dn,*p,*q,*r);A)7,8,8B) 7,8,7C) 8,7,7D) 8,7,825. 以下程序的正確運(yùn)行結(jié)果是【 A】。#incluedmain() int k=4,m=1,p; p=func(k,m); printf(“%d”,p); p=func(k,m); printf(“%dn”,

11、p);func(int a,int b) static int m=0,i=2; i+=m+1; m=i+a+b; return (m);A)8,17 B)8,16 C)8,20 D)8,826. 以下程序的功能是計(jì)算函數(shù)F(x,y,z)=(x+z)/(y-z)+(y+2z)/(x-2z)的值,請將程序補(bǔ)充完整。(A,D)#includefloat f(float x,float y) float value; value= 【1】; return value;main() float x,y,z,sum; scanf(%f%f%f,&x,&y,&z); sum=f(x+z,y-z)+f(【2

12、】); printf(sum=%fn,sum);【1】A) x/yB) x/zC) (x+z)/(y-z)D) x+z/y-z【2】A) y+2z,x-2zB) y+z,x-zC) x+z,y-zD) y+z*z,x-2*z27. 以下程序的功能是根據(jù)輸入的字母,在屏幕上顯示出字符數(shù)組中首字符與其相同的字符串,若不存在,則顯示“No find,good bye!”,請將程序補(bǔ)充完整。(B,D)#includechar PriStr(char ch1) int i=0,j=0; static char *ch2=how are you, glad to meet you,anything new

13、, everything is fine,very well,thank you,see you tomorrow; while(i+6) if(ch1=【1】 ) puts(【2】); j=1; return j;main() char ch; printf(nPleae enter a char:); ch=getchar(); ch=PriStr(ch); if(ch=【3】) puts(No find, good bye! );【1】A)ch2i0B)ch2i-10C)*ch2iD) *ch2i-10【2】A)ch2iB)*ch2iC)*ch2i-1D) ch2i-1【3】A)0B)4

14、8C) 0D) 3028. 以下程序是將輸入的一個(gè)整數(shù)反序打印出來,例如輸入1234,則輸出4321,輸入-1234,則輸出-4321。請將程序補(bǔ)充完整。(D,C)29. void printopp(long int n) int i=0; if(n=0) return ; else while(n) if(【1】) printf(%ld,n%10); else printf(%ld,-n%10); i+; 【2】; main() long int n; scanf(%ld,&n); printopp(n); printf(n);【1】A)n0&i=0B)n0&i=0D)n0|i=0【2】A)

15、n%=10B)n%=(-10)C)n/=10D)n/=)-10)29. 下面的程序用遞歸定義的方法實(shí)現(xiàn)求菲波拉契數(shù)列1、1、2、3、5、8、13、21第7項(xiàng)的值fib(7),菲波拉契數(shù)列第1項(xiàng)和第2項(xiàng)的值都是1。請將程序補(bǔ)充完整。(C,D)#includelong fib(【1】) switch(g) case 0: return 0; case 1: case 2: return 1; return (【2】);main() long k; k=fib(7); printf(k=%dn,k);【1】A)gB)kC)long int gD)int k【2】A)fib(7)B)fib(g)C)f

16、ib(k)D)fib(g-1)+fib(g-2)30.有以下程序(A)int fun(int n) if(n=1) return 1; else return(n+fun(n-1);main() int x; scanf(%d,&x); x=fun(x); printf(%dn,x);程序執(zhí)行時(shí),若輸入10,程序的輸出結(jié)果是【 】。A)55B)54C)65D)4531. 下面是一個(gè)計(jì)算1至m的階乘并依次輸出的程序。程序中應(yīng)填入的正確選項(xiàng)是【 D】。#includedouble result=1;factorial( int j) result=result*j; return;main() i

17、nt m,i=0,x; printf(Please enter an integer:); scanf(%d,&m); for(;i+m;) x=factorial(i); printf(%d!=%.0fn, 【 】 ); A)i,factorial(i)B)i,xC)j,xD)i,result32. 以下程序的功能是求任意兩個(gè)整數(shù)a和b的最大公約數(shù),并予以顯示。請將程序補(bǔ)充完整。(B,A)#include#includelong codivisor(long n1,long n2) long t; while( n2!=0 ) 【1】; n1=n2; n2=t; return (【2】);m

18、ain() long a,b,x; printf(please input two numbers:); scanf(%ld%ld,&a,&b); x=codivisor(a,b); printf(maximum common divisor of %ld and %ld is : %ldn, a,b,x);【1】A)t=n1/n2B)t=n1%n2C)t=n2%n1D)t=n2/n1【2】A)labs(n1)B)labs(a)C)labs(b)D)labs(n2)33. 以下程序的功能是計(jì)算并顯示一個(gè)指定行數(shù)的楊輝三角形(形狀如下),請將程序補(bǔ)充完整。(C,B,A)1111211331146

19、4115101051程序:#include#define N 15void yanghui(int bN, int n) int i,j; for(i=0; 【1】; i+) bi0=1; bii=1; for(【2】;+i=n;) for(j=1;ji;j+) bij= 【3】 ; for(i=0;in;i+) for(j=0;j=i;j+) printf(%4d,bij); printf(n); main() int aNN=0,n; printf(please input size of yanghui triangle(=15); scanf(%d,&n); printf(n); ya

20、nghui(a,n);【1】A)iNB)i=NC)inD)i=n【2】A)i=0B)i=1C)i=2D)i=3【3】A)bi-1j-1+bi-1jB) bi-2j-1+bi-1j C)bi-1j-1+bi-1j+1D) bi-2j-2+bi-1j34. 下面的程序用來將一個(gè)十進(jìn)制正整數(shù)轉(zhuǎn)化成八進(jìn)制數(shù),例如輸入一個(gè)正整數(shù)25,則輸出31,請將程序補(bǔ)充完整。(D,C)#includemain() int i=0,j=0,a,b10=0; printf(nPlease input a integer: ); scanf(%d,&a); sub(a,b); for(;i10;i+) if(【1】)j+

21、; if(j!=0)printf(%d,bi); sub(int c, int d) int e, i=9; while(c!=0) e=c%8; di=e; 【2】; i-; return;【1】A)bi0B)bi-1!=0C)bi=0D)bi!=0【2】A)c=sub(c/8)B)c=c%8C)c=c/8D)c=e%835. 函數(shù)bisearch 的作用是應(yīng)用折半查找法從存有N個(gè)整數(shù)的升序數(shù)組a中對關(guān)鍵字key進(jìn)行查找。請將程序補(bǔ)充完整。(C,A,B)#include#define N 15bisearch(int aN, int key) int low=0, high=N-1, mid

22、; while(【1】) mid=(low+high)/2; if(keyamid) low=mid+1; else return mid; return 【3】 ;main() int bN,n,I,j; printf(Please input a %d element increasing sequence: , N); for(i=0;iN;i+) printf(b%d= ,i); scanf(%d,&bi); printf(Please input a searching key: ); scanf(%d,&n); j=bisearch(b,n); if(j-5) printf(Don

23、t find %dn,n); else printf(b%d=%dn,j,n);【1】A)lowhighB)low!=highC)low=highD)low=high-1【2】A)high=mid-1B)low=mid+1C)high=mid+1D)low=mid-1【3】A)0B)-10C)-1D)138. 以下程序是選出能被3整除且至少有一位是5的所有三位正整數(shù)k(個(gè)位為a0,十位為a1,百位為a2),打印出所有這樣的數(shù)及其個(gè)數(shù)。請將程序補(bǔ)充完整。(C,B,A)#includesub(int m,int n) int a0,a1,a2; a2=【1】; a1=【2】; a0=m%10; i

24、f(m%3=0 & (a2=5|a1=5|a0=5) printf(“%d”,m); n+; return n;main() int m=0,k; for(k=105;k=995;k+) m=sub(【3】); printf(nn=%dn,m);【1】A) m/10B) m%10C) m/100D) m%100【2】A) (m-a2*10)/10B) m/10-a2*10 C) m%10-a2*10D) m%100-m%10【3】A) k,mB) m,kC) k,nD) n,k39. 以下程序可計(jì)算10名學(xué)生1門課成績的平均分,要求使用無返回值函數(shù)實(shí)現(xiàn)。請將程序補(bǔ)充完整。(C,B,D)#inc

25、ludevoid average(float array10) int i=0; while(【1】) array0+=【2】; arrayi-1=array0/10;main() float score10; int i; printf(Please input 10 scores:n); for(i=0;i10;i+) scanf(%f,&scorei); average(score); printf(The average score is %.2fn,【3】 );【1】A)i=10B)i+10C)+i10D)i10【2】A)arrayi-1B)arrayiC)arrayi-D)arra

26、yi+【3】A)score8B)score0C)array8D)score9二讀程序?qū)懡Y(jié)果1. fun(int x,int y,int z) z =x*x+y*y;main ( ) int a=31; fun (6,3,a); printf (%d, a); (31)2. int f( ) static int i=0; int s=1;s+=i; i+;return s; main() int i,a=0; for(i=0;i5;i+) a+=f(); printf(%dn,a);(15)3. 運(yùn)行程序時(shí),若從鍵盤輸入asd af aa z67(回車),分析以下程序的輸出結(jié)果。#includ

27、e int fun(char *str) int i,j=0;for(i=0;stri!= ;i+)if(stri!= ) strj+=stri; strj= ;main() char str81;int n;printf(Input a string : );gets(str);fun(str);printf(%sn,str);(asd af aa z67)4.void s *p1,int *p2) int *t; t=p1,p1=p2,p2=t; printf(*p1=%d,*p2=%dn,*p1,*p2);main() int x=10,y=20; s); printf(x=%d,y=%

28、dn,x,y);(10,20)5.#includevoidfun(int *s, intm, int n) intt; while(mn) t=sm; sm=sn; sn=t; m+; n-;main() Int a5=1,2,3,4,5,k;fun(a,0,4);for(k=0;k5;k+) printf(%d ,ak);(5,4,3,2,1)6.int fun(char s) int n=0; while(*s=0) n=10*n+*s-0; s+; return(n);main() char s10=6,1,*,4,*,9,*,0,*; printf(%dn,fun(s); (61)7.#includeInt fun(int x) inty; if(x=0|x=1)return(3); y=x*x-fun(x-2) returny;main() int x,y; x=fun(3); y=fun(4); printf(%d, %dn, x ,y);(6,15)8.fun(int n,int *s) int f1, f2; if(n=1 | n=2) *s=1; else fun(n-1, &f1); fun(n-2, &f2); *s=f1+f2; main() int x; fun(6,&x)

溫馨提示

  • 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

提交評論