C语言函数习题集与答案解析Word文件下载.docx

上传人:b****3 文档编号:16362765 上传时间:2022-11-23 格式:DOCX 页数:31 大小:31.16KB
下载 相关 举报
C语言函数习题集与答案解析Word文件下载.docx_第1页
第1页 / 共31页
C语言函数习题集与答案解析Word文件下载.docx_第2页
第2页 / 共31页
C语言函数习题集与答案解析Word文件下载.docx_第3页
第3页 / 共31页
C语言函数习题集与答案解析Word文件下载.docx_第4页
第4页 / 共31页
C语言函数习题集与答案解析Word文件下载.docx_第5页
第5页 / 共31页
点击查看更多>>
下载资源
资源描述

C语言函数习题集与答案解析Word文件下载.docx

《C语言函数习题集与答案解析Word文件下载.docx》由会员分享,可在线阅读,更多相关《C语言函数习题集与答案解析Word文件下载.docx(31页珍藏版)》请在冰豆网上搜索。

C语言函数习题集与答案解析Word文件下载.docx

  D)实参将其值传递给形参,调用结束时形参并不将其值回传给实参

10.若函数调用时的实参为变量时,以下关于函数形参和实参的叙述中正确的是【】。

  A)函数的实参和其对应的形参共占同一存储单元

  B)形参只是形式上的存在,不占用具体存储单元

  C)同名的实参和形参占同一存储单元

  D)函数的形参和实参分别占用不同的存储单元

11.若用数组名作为函数调用的实参,则传递给形参的是【】。

  A)数组的首地址B)数组的第一个元素的值

  C)数组中全部元素的值D)数组元素的个数

12.若函数调用时,用数组名作为函数的参数,以下叙述中正确的是【】。

  A)实参与其对应的形参共用同一段存储空间

  B)实参与其对应的形参占用相同的存储空间

  C)实参将其地址传递给形参,同时形参也会将该地址传递给实参

  D)实参将其地址传递给形参,等同实现了参数之间的双向值的传递

13.如果一个函数位于C程序文件的上部,在该函数体说明语句后的复合语句中定义了一个变量,则该变量【】。

  A)为全局变量,在本程序文件围有效

  B)为局部变量,只在该函数有效

  C)为局部变量,只在该复合语句中有效

  D)定义无效,为非法变量

14.C语言中函数返回值的类型是由【】决定。

  A)return语句中的表达式类型

  B)调用函数的主调函数类型

  C)调用函数时临时

  D)定义函数时所指定的函数类型

15.若在一个C源程序文件中定义了一个允许其他源文件引用的实型外部变量a,则在另一文件中可使用的引用说明是【】。

  A)externstaticfloata;

B)floata;

  C)externautofloata;

D)externfloata;

16.定义一个void型函数意味着调用该函数时,函数【】

  A)通过return返回一个用户所希望的函数值

  B)返回一个系统默认值

  C)没有返回值

  D)返回一个不确定的值

17.若定义函数float*fun(),则函数fun的返回值为【】。

  A)一个实数B)一个指向实型变量的指针

  C)一个指向实型函数的指针D)一个实型函数的入口地址

18. C语言规定,程序中各函数之间【】。

  A)既允许直接递归调用也允许间接递归调用

  B)不允许直接递归调用也不允许间接递归调用

  C)允许直接递归调用不允许间接递归调用

  D)不允许直接递归调用允许间接递归调用

19.若程序中定义函数

floatmyadd(floata,floatb)

{returna+b;

}

  并将其放在调用语句之后,则在调用之前应对该函数进行说明。

以下说明中错误的是【】。

  A)floatmyadd(floata,b);

  B)floatmyadd(floatb,floata);

  C)floatmyadd(float,float);

  D)floatmyadd(floata,floatb);

20.关于以下fun函数的功能叙述中,正确的是【】。

intfun(char*s)

{

char*t=s;

while(*t++);

t--;

return(t-s);

} 

  A)求字符串s的长度 B)比较两个串的大小

  C)将串s复制到串t D)求字符串s所占字节数

21.下面程序段运行后的输出结果是【】(假设程序运行时输入5,3回车)

inta,b;

voidswap()

intt;

t=a;

a=b;

b=t;

main()

scanf("

%d,%d"

&

a,&

b);

swap();

printf("

a=%d,b=%d\n"

a,b);

  A)a=5,b=3B)a=3,b=5C)5,3D)3,5

22.以下程序运行后的输出结果是【】。

fun(inta,intb)

if(a>

b)returna;

elsereturnb;

intx=3,y=8,z=6,r;

r=fun(fun(x,y),2*z);

printf("

%d\n"

r);

A)3B)6C)8D)12

23.以下程序的运行结果是【】。

voidf(inta,intb)

intx=1,y=3,z=2;

if(x>

y)f(x,y);

elseif(y>

z)f(x,z);

elsef(x,z);

%d,%d,%d\n"

x,y,z);

A)1,2,3B)3,1,2 C)1,3,2D)2,3,1

24.以下程序运行后的输出结果为【】。

int*f(int*x,int*y)

if(*x<

*y)returnx;

elsereturny;

inta=7,b=8,*p,*q,*r;

p=&

a,q=&

b;

r=f(p,q);

*p,*q,*r);

A)7,8,8B)7,8,7 C)8,7,7D)8,7,8

25.以下程序的正确运行结果是【】。

#inclued<

stdio.h>

intk=4,m=1,p;

p=func(k,m);

printf(“%d”,p);

printf(“%d\n”,p);

func(inta,intb)

staticintm=0,i=2;

i+=m+1;

m=i+a+b;

return(m);

  A)8,17B)8,16C)8,20D)8,8

26.以下程序的功能是计算函数F(x,y,z)=(x+z)/(y-z)+(y+2×

z)/(x-2×

z)的值,请将程序补充完整。

#include<

floatf(floatx,floaty)

floatvalue;

value=【1】;

returnvalue;

floatx,y,z,sum;

%f%f%f"

&

x,&

y,&

z);

sum=f(x+z,y-z)+f(【2】);

sum=%f\n"

sum);

  【1】A)x/yB)x/z C)(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*z

27.以下程序的功能是根据输入的字母,在屏幕上显示出字符数组中首字符与其相同的字符串,若不存在,则显示“Nofind,goodbye!

”,请将程序补充完整。

charPriStr(charch1)

inti=0,j=0;

staticchar*ch2[]={"

howareyou"

"

gladtomeetyou"

"

anythingnew"

everythingisfine"

verywell,thankyou"

seeyoutomorrow"

};

while(i++<

6)

if(ch1==【1】)

{

puts(【2】);

j=1;

}

returnj;

charch;

\nPleaeenterachar:

"

);

ch=getchar();

ch=PriStr(ch);

if(ch==【3】)

puts("

Nofind,goodbye!

"

【1】A)ch2[i][0]B)ch2[i-1][0]C)*ch2[i]D)*ch2[i-1][0]

【2】A)ch2[i]B)*ch2[i]C)*ch2[i-1]D)ch2[i-1]

【3】A)’0’B)’48’ C)0D)30

28.以下程序是将输入的一个整数反序打印出来,例如输入1234,则输出4321,输入-1234,则输出-4321。

请将程序补充完整。

voidprintopp(longintn)

inti=0;

if(n==0)

return;

else

while(n)

if(【1】)printf("

%ld"

n%10);

elseprintf("

-n%10);

i++;

【2】;

longintn;

n);

printopp(n);

\n"

  【1】A)n<

0&

&

i==0B)n<

0||i==0C)n>

i==0D)n>

0||i==0

  【2】A)n%=10B)n%=(-10)C)n/=10D)n/=)-10)

29.下面的程序用递归定义的方法实现求菲波拉契数列1、1、2、3、5、8、13、21……第7项的值fib(7),菲波拉契数列第1项和第2项的值都是1。

longfib(【1】)

switch(g)

case0:

return0;

case1:

case2:

return1;

return(【2】);

longk;

k=fib(7);

k=%d\n"

k);

  【1】A)gB)kC)longintgD)intk

  【2】A)fib(7)B)fib(g)C)fib(k)D)fib(g-1)+fib(g-2)

30.有以下程序

intfun(intn)

if(n==1)return1;

elsereturn(n+fun(n-1));

intx;

%d"

x);

x=fun(x);

x);

  程序执行时,若输入10,程序的输出结果是【】。

  A)55  B)54  C)65  D)45

31.下面是一个计算1至m的阶乘并依次输出的程序。

程序中应填入的正确选项是【】。

doubleresult=1;

factorial(intj)

result=result*j;

return;

intm,i=0,x;

Pleaseenteraninteger:

m);

for(;

i++<

m;

x=factorial(i);

%d!

=%.0f\n"

【】);

  A)i,factorial(i)B)i,xC)j,xD)i,result

32.以下程序的功能是求任意两个整数a和b的最大公约数,并予以显示。

stdlib.h>

longcodivisor(longn1,longn2)

longt;

while(n2!

=0)

{【1】;

n1=n2;

n2=t;

{

longa,b,x;

pleaseinputtwonumbers:

%ld%ld"

a,&

x=codivisor(a,b);

maximumcommondivisorof%ldand%ldis:

%ld\n"

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.以下程序的功能是计算并显示一个指定行数的辉三角形(形状如下),请将程序补充完整。

1

11

121

1331

14641

15101051

程序:

#defineN15

voidyanghui(intb[][N],intn)

inti,j;

for(i=0;

【1】;

i++)

b[i][0]=1;

b[i][i]=1;

for(【2】;

++i<

=n;

for(j=1;

j<

i;

j++)

b[i][j]=【3】;

i<

n;

i++)

for(j=0;

=i;

%4d"

b[i][j]);

inta[N][N]={0},n;

pleaseinputsizeofyanghuitriangle(<

=15)"

yanghui(a,n);

  【1】A)i<

NB)i<

=NC)i<

nD)i<

=n

  【2】A)i=0B)i=1C)i=2D)i=3

  【3】A)b[i-1][j-1]+b[i-1][j]B)b[i-2][j-1]+b[i-1][j]

    C)b[i-1][j-1]+b[i-1][j+1]D)b[i-2][j-2]+b[i-1][j]

34.下面的程序用来将一个十进制正整数转化成八进制数,例如输入一个正整数25,则输出31,请将程序补充完整。

inti=0,j=0,a,b[10]={0};

\nPleaseinputainteger:

a);

sub(a,b);

10;

if(【1】)j++;

if(j!

=0)printf("

b[i]);

sub(intc,intd[])

inte,i=9;

while(c!

=0)

{

e=c%8;

d[i]=e;

i--;

  【1】A)b[i]<

0B)b[i-1]!

=0C)b[i]<

=0D)b[i]!

=0

  【2】A)c=sub(c/8)B)c=c%8C)c=c/8D)c=e%8

35.函数bisearch的作用是应用折半查找法从存有N个整数的升序数组a中对关键字key进行查找。

bisearch(inta[N],intkey)

intlow=0,high=N-1,mid;

while(【1】)

mid=(low+high)/2;

if(key<

a[mid])

else

if(key>

low=mid+1;

returnmid;

return【3】;

intb[N],n,I,j;

Pleaseinputa%delementincreasingsequence:

N);

N;

b[%d]="

i);

b[i]);

Pleaseinputasearchingkey:

j=bisearch(b,n);

if(j<

-5)

Don’tfind%d\n"

n);

b[%d]=%d\n"

j,n);

  【1】A)low<

highB)low!

=highC)low<

=highD)low<

=high-1

  【2】A)high=mid-1B)low=mid+1C)high=mid+1D)low=mid-1

  【3】A)0  B)-10C)-1D)1

36.如果程序及其运行结果显示如下,请将程序补充完整。

21046

1523

2478

5132

Thevalueis15.

func(【1】)

int【2】,j;

4;

b[3][j]=2*b[0][j];

b[3][j]);

b[3][j]=0;

if(b[i][j]<

5&

b[i][2]>

5)

k+=b[i][j];

returnk;

staticinta[4][4]={【3】};

inti,j,k;

k=func(a,9);

if(a[i][j]!

=0)

a[i][j]);

if(a[i][4]!

Thevalueis%d\n"

  

  【1】A)intb[4][],kB)intb[][4],kC)intb[4,4],intkD)intb[][4],intk

  【2】A)i=0B)i=1C)i=2D)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,3}

37.以下程序的功能是用二分法求方程f(x)=x41+x3+1=0在区间(-1.0,-0.5)中的一个实根,并要求绝对误差不超过0.001。

二分法的基本思想是:

假设在区间(a,b)中f(a)与f(b)异号,先取区间的中点m,如果f(m)与f(a)异号,则取新的解区间为(a,m),否则取新的解区间为(m,b)。

不断对解区间对分,直到解区间已经小于给定的误差时,取该区间的中点作为解的近似值。

math.h>

floatf(floatx)

return(pow(x,41)+pow(x,3)+1);

floatsolv(floata,floatb)

floatm;

m=(a+b)/2;

while(f(m)*f(b)!

if(【1】)a=m;

elseb=m;

if(【2】)break;

returnm;

floatr;

r=solv(-1.0,-0.5);

approximate

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 经管营销 > 金融投资

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1