ImageVerifierCode 换一换
格式:DOCX , 页数:31 ,大小:30.83KB ,
资源ID:17233978      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/17233978.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(C语言函数习题及答案Word文档下载推荐.docx)为本站会员(b****3)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

C语言函数习题及答案Word文档下载推荐.docx

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