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