C语言函数习题及答案Word下载.docx

上传人:b****6 文档编号:22272268 上传时间:2023-02-03 格式:DOCX 页数:39 大小:38.22KB
下载 相关 举报
C语言函数习题及答案Word下载.docx_第1页
第1页 / 共39页
C语言函数习题及答案Word下载.docx_第2页
第2页 / 共39页
C语言函数习题及答案Word下载.docx_第3页
第3页 / 共39页
C语言函数习题及答案Word下载.docx_第4页
第4页 / 共39页
C语言函数习题及答案Word下载.docx_第5页
第5页 / 共39页
点击查看更多>>
下载资源
资源描述

C语言函数习题及答案Word下载.docx

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

C语言函数习题及答案Word下载.docx

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

 C)externautofloat a;

ﻩﻩD)externfloata;

16。

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

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

B)返回一个系统默认值

C)没有返回值

 D)返回一个不确定的值

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

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

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

18。

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

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

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

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

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

19、若程序中定义函数

float myadd(floata,floatb)

{returna+b;

并将其放在调用语句之后,则在调用之前应对该函数进行说明、以下说明中错误的是【】。

 A)float myadd( float a,b);

B)floatmyadd(floatb,floata);

 C)floatmyadd(float,float);

  D)float myadd(floata,float b);

20。

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

int fun(char*s)

{ 

 char*t=s;

while(*t++);

 t——;

return(t-s);

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

 C) 将串s复制到串tD) 求字符串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=3ﻩﻩB)a=3,b=5ﻩC)5,3ﻩﻩD)3,5

22。

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

fun(inta,int b)

{

if(a〉b)ﻩreturna;

elsereturnb;

main()

{ﻩ

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

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

  printf("

%d\n”,r);

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

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

voidf(inta,intb)

int t;

  t=a;

a=b;

{ﻩ

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

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

elseif(y>

z) f(x,z);

 else f(x,z);

printf("

%d,%d,%d\n”,x,y,z);

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

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

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

if(*x〈*y)ﻩreturnx;

  elseﻩreturn y;

main()

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

  p=&

a,q=&

b;

r=f(p,q);

printf("%d,%d,%d\n",*p,*q,*r);

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

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

#inclued〈stdio。

h〉

 int k=4,m=1,p;

p=func(k,m);

printf(“%d”,p);

p=func(k,m);

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

func(inta,int b)

staticintm=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)的值,请将程序补充完整。

#include<stdio。

h>

floatf(floatx,float y)

float value;

 value=【1】;

return value;

main()

floatx,y,z,sum;

scanf(”%f%f%f”,&x,&

y,&z);

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

printf("

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-zﻩC)x+z,y-zﻩD)y+z*z,x-2*z

27。

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

"

请将程序补充完整。

#include<

stdio、h>

charPriStr(charch1)

 int i=0,j=0;

 staticchar*ch2[]={"

howareyou”,”glad to meet you"

"anything new”,   ”everythingisfine","very well,thankyou"

"

see youtomorrow"

};

while(i++<

6)

  if(ch1==【1】 )

{ﻩ

  puts(【2】);

 j=1;

 }

 returnj;

 charch;

printf("\nPleaeenter achar:

);

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)0ﻩD)30

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

请将程序补充完整。

voidprintopp(long int n)

  inti=0;

  if(n==0)

return ;

  else

while(n)

{

 if(【1】) printf("%ld"

n%10);

elseprintf(”%ld",-n%10);

i++;

  【2】;

 }

main()

long intn;

scanf("

%ld”,&

n);

 printopp(n);

printf("\n");

  【1】A)n<0&&i==0ﻩB)n〈0||i==0C)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、请将程序补充完整、

#include<

stdio。

h>

longfib(【1】)

 switch(g)

 {

case0:

 return0;

 case 1:

case 2:

return1;

 return (【2】);

main()

 longk;

 k=fib(7);

printf(”k=%d\n”,k);

 【1】A)gﻩﻩB)kﻩﻩC)longintgD)intk

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

30、有以下程序

intfun(int n)

  if(n==1)return1;

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

 int x;

scanf(”%d"

&

x);

 x=fun(x);

 printf("

%d\n”,x);

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

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

31。

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

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

#include〈stdio、h〉

doubleresult=1;

factorial(intj)

 result=result*j;

 return;

main()

intm,i=0,x;

 printf("

Pleaseenteraninteger:

scanf("%d”,&m);

for(;

i++〈m;

  {

x=factorial(i);

 printf("

%d!

=%。

0f\n"

【】);

 A)i,factorial(i)B)i,xﻩC)j,xD)i,result

32。

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

请将程序补充完整、

#include<stdio。

#include<

stdlib。

longcodivisor(longn1,long n2)

 longt;

while( n2!

=0)

{【1】;

 n1=n2;

 n2=t;

 return (【2】);

{ﻩ

longa,b,x;

 printf("pleaseinput twonumbers:

 scanf("

%ld%ld",&a,&

x=codivisor(a,b);

printf("

maximummondivisorof %ldand %ldis:

%ld\n”,a,b,x);

 【1】A)t=n1/n2ﻩB)t=n1%n2ﻩC)t=n2%n1D)t=n2/n1

 【2】A)labs(n1)B)labs(a)C)labs(b)ﻩD)labs(n2)

33。

 以下程序的功能是计算并显示一个指定行数的杨辉三角形(形状如下),请将程序补充完整。

11

12ﻩ1

13ﻩ31

1ﻩ464ﻩ1

1ﻩ5101051

程序:

#include<

stdio。

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

j<=i;

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

\n”);

 }

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

printf(”pleaseinput sizeofyanghui triangle(〈=15)”);

scanf("

%d”,&

n);

printf("

 yanghui(a,n);

  【1】A)i<NﻩB)i<=NC)i〈nﻩD)i〈=n

【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,请将程序补充完整、

#include〈stdio、h>

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

 printf("

\nPleaseinputa integer:

”);

scanf(”%d”,&a);

 sub(a,b);

for(;

i<10;

 {ﻩ

  if(【1】)ﻩj++;

  if(j!

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

sub(intc,intd[])

{

inte,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/8D)c=e%8

35。

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

#include〈stdio、h>

#defineN15

bisearch(inta[N],intkey)

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

while(【1】)

mid=(low+high)/2;

 if(key<a[mid])

    【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 elementincreasingsequence:

 N);

for(i=0;

i<

N;

{ﻩ

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

scanf("

%d"

b[i]);

 }

printf("Pleaseinputasearchingkey:

scanf(”%d"

&n);

j=bisearch(b,n);

 if(j〈—5)

 printf(”Don'

tfind %d\n",n);

else

 printf("

b[%d]=%d\n”,j,n);

  【1】A)low<

highﻩﻩﻩB)low!

=highﻩﻩC)low<

=highﻩD)low〈=high—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)1

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

2ﻩ104ﻩ6

15ﻩ2ﻩ3

2ﻩ478

513ﻩ2

Thevalueis15、

#include〈stdio、h>

func(【1】)

int 【2】,j;

 for(j=0;

j〈4;

j++)

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

  printf("

%4d",b[3][j]);

   b[3][j]=0;

 printf("

\n”);

 for(j=0;

j<4;

j++)

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

 for(i=0;

4;

i++)

for(j=0;

j<

4;

if(a[i][j]!

=0)ﻩ

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

 if(a[i][4]!

=0)

  printf(”\n");

 printf("

Thevalueis%d\n”,k);

 【1】A)intb[4][],kﻩB)intb[][4],kﻩC)int b[4,4],intkﻩD)intb[][4],intk

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

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

#include<stdio、h〉

#include〈math。

h>

floatf(float x)

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

floatsolv(floata,float b)

 floatm;

  m=(a+b)/2;

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

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

当前位置:首页 > 高等教育 > 农学

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

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