2024年6月8日发(作者:)

C语言函数练习题

一、选择题

1. 一个完整的C源程序是【 】。

A〕要由一个主函数或一个以上的非主函数构成

B〕由一个且仅由一个主函数和零个以上的非主函数构成

C〕要由一个主函数和一个以上的非主函数构成

D〕由一个且只有一个主函数或多个非主函数构成

2. 以下关于函数的表达中正确的选项是【 】。

A〕C语言程序将从源程序中第一个函数开始执行

B〕可以在程序中由用户指定任意一个函数作为主函数,程序将从此开始执行

C〕C语言规定必须用main作为主函数名,程序将从此开始执行,在此结束

D〕main可作为用户标识符,用以定义任意一个函数

3. 以下关于函数的表达中不正确的选项是【 】。

A〕C程序是函数的集合,包括标准库函数和用户自定义函数

B〕在C语言程序中,被调用的函数必须在main函数中定义

C〕在C语言程序中,函数的定义不能嵌套

D〕在C语言程序中,函数的调用可以嵌套

4. 在一个C程序中,【 】。

A〕main函数必须出现在所有函数之前

B〕main函数可以在任何地方出现

C〕main函数必须出现在所有函数之后

D〕main函数必须出现在固定位置

5. 假设在C语言中未说明函数的类型,那么系统默认该函数的数据类型是【 】

A〕float B〕long

C〕int D〕double

6. 以下关于函数表达中,错误的选项是【 】。

A〕函数未被调用时,系统将不为形参分配内存单元

B〕实参与形参的个数应相等,且实参与形参的类型必须对应一致

C〕当形参是变量时,实参可以是常量、变量或表达式

D〕形参可以是常量、变量或表达式

7. 假设函数调用时参数为根本数据类型的变量,以下表达正确的选项是【 】。

A〕实参与其对应的形参共占存储单元

B〕只有当实参与其对应的形参同名时才共占存储单元

C〕实参与对应的形参分别占用不同的存储单元

D〕实参将数据传递给形参后,立即释放原先占用的存储单元

9. 函数调用时,当实参和形参都是简单变量时,他们之间数据传递的过程是【 】。

A〕实参将其地址传递给形参,并释放原先占用的存储单元

B〕实参将其地址传递给形参,调用结束时形参再将其地址回传给实参

C〕实参将其值传递给形参,调用结束时形参再将其值回传给实参

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〕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〕既允许直接递归调用也允许间接递归调用

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函数的功能表达中,正确的选项是【 】。

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

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

fun(int a, int b)

{

if(a>b) return a;

else return b;

}

main()

{

int x=3,y=8,z=6,r;

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

printf("%dn",r);

}

A) 3 B) 6 C) 8

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

void f(int a, int b)

{

C)5,3 D)3,5

D) 12

int t;

t=a; a=b; b=t;

}

main()

{

int x=1, y=3, z=2;

if(x>y) f(x,y);

else if(y>z) f(x,z);

else f(x,z);

printf("%d,%d,%dn",x,y,z);

}

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

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

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,8 B) 7,8,7 C) 8,7,7 D) 8,7,8

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

#inclued

main()

{

int k=4,m=1,p;

p=func(k,m);

printf(“%d〞,p);

p=func(k,m);

printf(“%dn〞,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,8

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

完整。(A,D)

#include

float 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】);

printf("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〕 y+z,x-z C〕 x+z,y-z D〕 y+z*z,x-2*z

27. 以下程序的功能是根据输入的字母,在屏幕上显示出字符数组中首字符与其相同的字符

串,假设不存在,那么显示“No find,good bye!〞,请将程序补充完整。(B,D)

#include

char PriStr(char ch1)

{

int i=0,j=0;

static char *ch2[]={"how are you", "glad to meet you","anything new",

"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〕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〕 0 D〕 30

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

-1234,那么输出-4321。请将程序补充完整。(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〕n<0&&i==0 B〕n<0||i==0 C〕n>0&&i==0 D〕n>0||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。请将程序补充完整。(C,D)

#include

long 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〕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.有以下程序(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);

}

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

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

31. 下面是一个计算1至m的阶乘并依次输出的程序。程序中应填入的正确选项是【 D】。

#include

double result=1;

factorial( int j)

{

result=result*j;

return;

}

main()

{

int m,i=0,x;

printf("Please enter an integer:");

scanf("%d",&m);

for(;i++

{

x=factorial(i);

printf("%d!=%.0fn", 【 】 );

}

}

A〕i,factorial(i) B〕i,x C〕j,x D〕i,result

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

整。(B,A)

#include

#include

long codivisor(long n1,long n2)

{

long t;

while( n2!=0 )

{【1】; n1=n2; n2=t;}

return (【2】);

}

main()

{

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

完整。(C,B,A)

1

1 1

1 2 1

1 3 3 1

1 4 6 4 1

1 5 10 10 5 1

程序:

#include

#define N 15

void yanghui(int b[][N], int n)

{

int i,j;

for(i=0; 【1】; i++)

{

b[i][0]=1; b[i][i]=1;

}

for(【2】;++i<=n;)

for(j=1;j

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

for(i=0;i

{

for(j=0;j<=i;j++)

printf("%4d",b[i][j]);

printf("n");

}

}

main()

{

int a[N][N]={0},n;

printf("please input size of yanghui triangle(<=15)");

scanf("%d",&n);

printf("n");

yanghui(a,n);

}

【1】A〕i

【2】A〕i=0 B〕i=1 C〕i=2 D〕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,请将程序补充完整。(D,C)

#include

main()

{

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

printf("nPlease input a integer: ");

scanf("%d",&a);

sub(a,b);

for(;i<10;i++)

{

if(【1】) j++;

if(j!=0) printf("%d",b[i]);

}

}

sub(int c, int d[])

{

int e, i=9;

while(c!=0)

{

e=c%8;

d[i]=e;

【2】;

i--;

}

return;

}

【1】A〕b[i]<0 B〕b[i-1]!=0 C〕b[i]<=0 D〕b[i]!=0

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

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

进行查找。请将程序补充完整。(C,A,B)

#include

#define N 15

bisearch(int a[N], int key)

{

int low=0, high=N-1, mid;

while(【1】)

{

mid=(low+high)/2;

if(key

【2】;

else

if(key>a[mid])

low=mid+1;

else

return mid;

}

return 【3】 ;

}

main()

{

int b[N],n,I,j;

printf("Please input a %d element increasing sequence: ", N);

for(i=0;i

{

printf("b[%d]= ",i);

scanf("%d",&b[i]);

}

printf("Please input a searching key: ");

scanf("%d",&n);

j=bisearch(b,n);

if(j<-5)

printf("Don’t find %dn",n);

else

printf("b[%d]=%dn",j,n);

}

【1】A)low

【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)1

38. 以下程序是选出能被3整除且至少有一位是5的所有三位正整数k(个位为a0,十位为a1,

百位为a2),打印出所有这样的数及其个数。请将程序补充完整。(C,B,A)

#include

sub(int m,int n)

{

int a0,a1,a2;

a2=【1】;

a1=【2】;

a0=m%10;

if(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/10 B) m%10 C) m/100 D) m%100

【2】A) (m-a2*10)/10 B) m/10-a2*10 C) m%10-a2*10 D) m%100-m%10

【3】A) k,m B) m,k C) k,n D) n,k

39. 以下程序可计算10名学生1门课成绩的平均分,要求使用无返回值函数实现。请将程

序补充完整。(C,B,D)

#include

void average(float array[10])

{

int i=0;

while(【1】)

array[0]+=【2】;

array[i-1]=array[0]/10;

}

main()

{

float score[10];

int i;

printf("Please input 10 scores:n");

for(i=0;i<10;i++)

scanf("%f",&score[i]);

average(score);

printf("The average score is %.2fn",【3】 );

}

【1】A〕i<=10 B〕i++<10 C〕++i<10

【2】A〕array[i-1] B〕array[i] C〕array[i--]

【3】A〕score[8] B〕score[0] C〕array[8]

D〕i<10

D〕array[i++]

D〕score[9]

二.读程序写结果

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;i<5;i++)

a+=f();

printf("%dn",a);

}(15)

3. 运行程序时,假设从键盘输入asd af aa z67〔回车〕,分析以下程序的输出结果。

#include

int fun(char *str)

{

int i,j=0;

for(i=0;str[i]!=’ ’;i++)

if(str[i]!=’ ’)

str[j++]=str[i];

str[j]=’ ’;

}

main()

{

char str[81];

int n;

printf("Input a string : ");

gets(str);

fun(str);

printf("%sn",str);

}(asd af aa z67)

4.

void swap(int *p1,int *p2)

{

int *t;

t=p1,p1=p2,p2=t;

printf("*p1=%d,*p2=%dn",*p1,*p2);

}

main()

{

int x=10,y=20;

swap(&x,&y);

printf("x=%d,y=%dn",x,y);

}(10,20)

5.

#include

void fun(int *s, int m, int n)

{

int t;

while(m

{t=s[m]; s[m]=s[n]; s[n]=t; m++; n--;}

}

main()

{

Int a[5]={1,2,3,4,5},k;

fun(a,0,4);

for(k=0;k<5;k++)

printf("%d ",a[k]);

}(5,4,3,2,1)

6.

int fun(char s[])

{

int n=0;

while(*s<='9'&&*s>='0')

{

n=10*n+*s-'0';

s++; }

return(n);

}

main()

{

char s[10]={'6','1','*','4','*','9','*','0','*'};

printf("%dn",fun(s)); }(61)

7.

#include

Int fun(int x)

{

int y;

if(x==0||x==1) return(3);

y=x*x-fun(x-2)

return y;

}

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);

printf("%dn",x); }

三、填空题

1. 以下程序实现了计算x的n次方,请将程序填写完整。

float power(float x,int n)

{ int i;

float t=1;

for(i=1;i<=n;i++)

t=t*x;

return t; }

main( )

{ float x,y;

int n;

scanf("%f,%d",&x,&n);

y=power(x,n);

printf("%8.2fn",y) ;

}

2. 以下程序实现了求两个数的最大公约数,请将程序填写完整。

int divisor(int a,int b)

{ int r;

r=a%b;

while(r!=0)

{ a=b;b=r;r=a%b;}

return b;

}

void main()

{ int a,b,d,t;

scanf("%d %d",&a,&b);

if (a

{ t=a; a=b; b=t; }

d=divisor(a,b);

printf("n gcd=%d",d);

}

3. 以下函数my_cmp( )的功能是比拟字符串s和t的大小,当s等于t时返回0,否那么

返回s和t的第一个不同字符的ASCII码差值,即s>t时返回正值,s

请将函数填写完整。

my_cmp(char *s,char *t)

{

while(*s == *t)

{

if (*s==’0’) return 0;

++s; ++t;

}

Return *s-*t;

}

4. 以下程序的功能是:删去一维数组中所有相同的数,使之只剩一个。数组中的数已按由小

到大的顺序排列,函数返回删除后数组中数据的个数。请将程序填写完整。

例如,假设一维数组中的数据是: 2 2 2 3 4 4 5 6 6 6 6 7 7 8 9 9 10 10 10

删除后,数组中的内容应该是: 2 3 4 5 6 7 8 9 10。

#include

#define N 80

int fun(int a[], int n)

{ int i,j=1;

for(i=1;i

if(a[j-1]!=a[i])

a[j++]=a[i];

Return j;

}

main( )

{

int a[N]={2,2,2,3,4,4,5,6,6,6,6,7,7,8,9,9,10,10,10},i,n=19;

printf("The original data:n");

for(i=0;i

printf(“%d 〞,a[i]);

n=fun(a,n);

printf("nThe data after deleted: n");

for(i=0; i

printf(“%d 〞,a[i]); }

参 考 答 案

一、选择题

1. B 2. C 3. B 4. B 5. C 6. D 7. C 9. D 10. D

11. A 12.

21. A 22.

27.【2】D

30. A

33.【3】A

38.【1】C

A 13. C

D 23. C

27.【3】C

31. D

34.【1】D

38.【2】B

14. D 15.

24. B 25.

28.【1】D

32.【1】B

34.【2】C

38.【3】A

D 16. C 17. B 18. A 19. A 20. A

A 26.【1】A 26.【2】D 27.【1】B

28.【2】C 29.【1】C 29.【2】D

32.【2】A 33.【1】C 33.【2】B

35.【1】C 35.【2】A 35.【3】B

39.【1】C 39.【2】B 39.【3】D

二、读程序写结果:

1. 31 2. 15 3. asd af aa z67 4. *p1=20,*p2=10 x=10,y=20

5. 5 4 3 2 1 6. 61 7. 6,15 8. 8

三、填空题

1.【1】 return t 2.【2】 r!=0 3.【3】 *s == ‘0’ 【4】 *s-*t

4.【5】 != 【6】 j

求两个整数的最大公约数、最小公倍数

分析:求最大公约数的算法思想:〔最小公倍数=两个整数之积/最大公约数〕

〔1〕 对于两数m,n,使得m>n;〔2〕 m除以n得余数r;

〔3〕 假设r=0,那么n为求得的最大公约数,算法结束;否那么执行〔4〕;

〔4〕 m←n,n←r,再重复执行〔2〕