1、D)实参将其值传递给形参,调用结束时形参并不将其值回传给实参10. 若函数调用时的实参为变量时,以下关于函数形参和实参的叙述中正确的是【 】。A)函数的实参和其对应的形参共占同一存储单元B)形参只是形式上的存在,不占用具体存储单元C)同名的实参和形参占同一存储单元D)函数的形参和实参分别占用不同的存储单元11. 若用数组名作为函数调用的实参,则传递给形参的是 【 】。A) 数组的首地址 B) 数组的第一个元素的值 C) 数组中全部元素的值 D) 数组元素的个数12. 若函数调用时,用数组名作为函数的参数,以下叙述中正确的是【 】。A)实参与其对应的形参共用同一段存储空间B)实参与其对应的形参占
2、用相同的存储空间C)实参将其地址传递给形参,同时形参也会将该地址传递给实参D)实参将其地址传递给形参,等同实现了参数之间的双向值的传递13. 如果一个函数位于C程序文件的上部,在该函数体内说明语句后的复合语句中定义了一个变量,则该变量【 】。A)为全局变量,在本程序文件范围内有效B)为局部变量,只在该函数内有效C)为局部变量,只在该复合语句中有效D)定义无效,为非法变量14. C语言中函数返回值的类型是由【 】决定。A)return语句中的表达式类型 B)调用函数的主调函数类型 C)调用函数时临时 D)定义函数时所指定的函数类型15. 若在一个C源程序文件中定义了一个允许其他源文件引用的实型外
3、部变量a,则在另一文件中可使用的引用说明是【 】。A)extern static float a; B)float a;C)extern auto float a; D)extern float a;16. 定义一个void型函数意味着调用该函数时,函数【 】A)通过return返回一个用户所希望的函数值B)返回一个系统默认值C)没有返回值D)返回一个不确定的值17. 若定义函数float *fun( ),则函数fun的返回值为【 】。A)一个实数 B)一个指向实型变量的指针C)一个指向实型函数的指针 D)一个实型函数的入口地址18.C语言规定,程序中各函数之间【 】。A)既允许直接递归调用也
4、允许间接递归调用B)不允许直接递归调用也不允许间接递归调用C)允许直接递归调用不允许间接递归调用D)不允许直接递归调用允许间接递归调用19. 若程序中定义函数float myadd(float a, float b) return a+b;并将其放在调用语句之后,则在调用之前应对该函数进行说明。以下说明中错误的是【 】。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. 关于以下fun函数的功能叙述中,正
5、确的是【 】。int fun(char *s) char *t=s; while(*t+) ; t-; return(t-s);A) 求字符串s的长度 B) 比较两个串的大小C) 将串s复制到串t D) 求字符串s所占字节数21. 下面程序段运行后的输出结果是【 】 (假设程序运行时输入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=3 B) a=3,b=5 C)5,3 D)3,522. 以下程序运行后的
6、输出结果是【 】。fun(int a, int b) if(ab) return a; else return b; int x=3,y=8,z=6,r; r=fun(fun(x,y),2*z); printf(%dn,r);A) 3 B) 6 C) 8 D) 1223. 以下程序的运行结果是【 】。void f(int a, int b) int x=1, y=3, z=2; if(xy) f(x,y); else if(yz) f(x,z); else f(x,z);%d,%d,%dn,x,y,z);A) 1,2,3 B) 3,1,2 C) 1,3,2 D) 2,3,124. 以下程序运行
7、后的输出结果为【 】。int *f(int *x, int *y) if(*x*y) return x; else return y; int a=7,b=8,*p,*q,*r; p=&a, q=&b; r=f(p,q);,*p,*q,*r);A) 7,8,8 B) 7,8,7 C) 8,7,7 D) 8,7,825. 以下程序的正确运行结果是【 】。#inclued int k=4,m=1,p; p=func(k,m); printf(“%d”,p); printf(“%dn”,p);func(int a,int b) static int m=0,i=2; i+=m+1; m=i+a+b;
8、 return (m);A)8,17 B)8,16 C)8,20 D)8,826. 以下程序的功能是计算函数F(x,y,z)=(x+z)/(y-z)+(y+2z)/(x-2z)的值,请将程序补充完整。#includefloat f(float x,float y) float value; value= 【1】; return value; float x,y,z,sum;%f%f%f,&x,&y,&z); sum=f(x+z,y-z)+f(【2】);sum=%fn,sum);【1】A) x/y B) x/z C) (x+z)/(y-z) D) x+z/y-z【2】A) y+2z,x-2z B
9、) y+z,x-z C) x+z,y-z D) y+z*z,x-2*z27. 以下程序的功能是根据输入的字母,在屏幕上显示出字符数组中首字符与其相同的字符串,若不存在,则显示“No find,good bye!”,请将程序补充完整。char PriStr(char ch1) int i=0,j=0; static char *ch2=how are you, glad to meet you,anything neweverything is finevery well,thank yousee you tomorrow; while(i+6) if(ch1=【1】 ) puts(【2】);
10、j=1; return j; char ch;nPleae enter a char:); ch=getchar(); ch=PriStr(ch); if(ch=【3】) puts(No find, good bye! 【1】A)ch2i0 B)ch2i-10 C)*ch2i D) *ch2i-10【2】A)ch2i B)*ch2i C)*ch2i-1 D) ch2i-1【3】A)0 B)48 C) 0 D) 3028. 以下程序是将输入的一个整数反序打印出来,例如输入1234,则输出4321,输入-1234,则输出-4321。请将程序补充完整。void printopp(long int n
11、) int i=0; if(n=0) return ; else while(n) if(【1】) printf(%ld,n%10); else printf(,-n%10); i+; 【2】; long int n;n); printopp(n);n【1】A)n0&i=0 B)ni=0 D)n0|i=0【2】A)n%=10 B)n%=(-10) C)n/=10 D)n/=)-10)29. 下面的程序用递归定义的方法实现求菲波拉契数列1、1、2、3、5、8、13、21第7项的值fib(7),菲波拉契数列第1项和第2项的值都是1。long fib(【1】) switch(g) case 0: r
12、eturn 0; case 1: case 2: return 1; return (【2】); long k; k=fib(7);k=%dn,k);【1】A)g B)k C)long int g D)int k【2】A)fib(7) B)fib(g) C)fib(k) D)fib(g-1)+fib(g-2)30.有以下程序int fun(int n) if(n=1) return 1; else return(n+fun(n-1); int x;%dx); x=fun(x);,x);程序执行时,若输入10,程序的输出结果是【 】。A)55 B)54 C)65 D)4531. 下面是一个计算1
13、至m的阶乘并依次输出的程序。程序中应填入的正确选项是【 】。double result=1;factorial( int j) result=result*j; return; int m,i=0,x;Please enter an integer:m); for(;i+long codivisor(long n1,long n2) long t; while( n2!=0 ) 【1】; n1=n2; n2=t; long a,b,x;please input two numbers:%ld%lda,& x=codivisor(a,b);maximum common divisor of %l
14、d and %ld is : %ldn, a,b,x);【1】A)t=n1/n2 B)t=n1%n2 C)t=n2%n1 D)t=n2/n1【2】A)labs(n1) B)labs(a) C)labs(b) D)labs(n2)33. 以下程序的功能是计算并显示一个指定行数的杨辉三角形(形状如下),请将程序补充完整。11 11 2 11 3 3 11 4 6 4 11 5 10 10 5 1程序:#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
15、=1;ji;j+) bij= 【3】 ;in;i+) for(j=0;=i;%4d,bij); int aNN=0,n;please input size of yanghui triangle(=15) yanghui(a,n);【1】A)iN B)i=N C)in D)i=n【2】A)i=0 B)i=1 C)i=2 D)i=3【3】A)bi-1j-1+bi-1j B) bi-2j-1+bi-1j C)bi-1j-1+bi-1j+1 D) bi-2j-2+bi-1j34. 下面的程序用来将一个十进制正整数转化成八进制数,例如输入一个正整数25,则输出31,请将程序补充完整。 int i=0,
16、j=0,a,b10=0;nPlease input a integer:a); sub(a,b);10; if(【1】) j+; if(j!=0) printf(,bi);sub(int c, int d) int e, i=9; while(c!=0) e=c%8; di=e; i-;【1】A)bi0 B)bi-1!=0 C)bi=0 D)bi!=0【2】A)c=sub(c/8) B)c=c%8 C)c=c/8 D)c=e%835. 函数bisearch 的作用是应用折半查找法从存有N个整数的升序数组a中对关键字key进行查找。bisearch(int aN, int key) int lo
17、w=0, high=N-1, mid; while(【1】) mid=(low+high)/2; if(key low=mid+1; return mid; return 【3】 ; int bN,n,I,j;Please input a %d element increasing sequence:, N);N;b%d= ,i);bi);Please input a searching key: j=bisearch(b,n); if(j-5)Dont find %dn,n);b%d=%dn,j,n);【1】A)lowhigh B)low!=high C)low=high D)low=hig
18、h-1【2】A)high=mid-1 B)low=mid+1 C)high=mid+1 D)low=mid-1【3】A)0 B)-10 C)-1 D)136. 如果程序及其运行结果显示如下,请将程序补充完整。2 10 4 61 5 2 32 4 7 85 1 3 2The value is 15.func(【1】) int 【2】,j;4; b3j=2*b0j;,b3j); b3j=0; if(bij5) k+=bij; return k; static int a44= 【3】; int i,j,k; k=func(a,9); if(aij!=0) ,aij); if(ai4!The val
19、ue is %dn【1】A)int b4,k B)int b4,k C)int b4,4,int k D)int b4,int k【2】A)i=0 B)i=1 C)i=2 D)i=3【3】A) 1,5,2,3,2,4,7,8,5,1,3,2 B)2,10,4,6,1,5,2,3,2,4,7,8,5,1,3,2 C) 1,5,2,3,2,4,7,8,5,1,2,3 D)2,10,4,6,1,5,2,3,2,4,7,8,5,1,2,337. 以下程序的功能是用二分法求方程f(x)=x41+x3+1=0在区间(-1.0,-0.5)中的一个实根,并要求绝对误差不超过0.001。二分法的基本思想是:假设
20、在区间(a,b)中f(a)与f(b)异号,先取区间的中点m,如果f(m)与f(a)异号,则取新的解区间为(a,m),否则取新的解区间为(m,b)。不断对解区间对分,直到解区间已经小于给定的误差时,取该区间的中点作为解的近似值。math.hfloat f(float x) return (pow(x,41)+pow(x,3)+1);float solv(float a,float b) float m; m=(a+b)/2; while(f(m)*f(b)! if(【1】) a=m; else b=m; if(【2】) break; return m; float r; r=solv(-1.0,-0.5);approx
copyright@ 2008-2022 冰豆网网站版权所有
经营许可证编号:鄂ICP备2022015515号-1