c语言函数习题及答案

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

函数习题
一、选择题
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. C程序中各函数之间可以通过多种方式传递数据,以下不能用于实现数据传递的方式是
【】。

A〕参数的形实〔哑实〕结合
B〕函数返回值
C〕全局变量
D〕同名的局部变量
8. 假设函数调用时参数为根本数据类型的变量,以下表达正确的选项是【】。

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〕e*tern static float a; B〕float a;
C〕e*tern auto float a; D〕e*tern 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函数的功能表达中,正确的选项是【】。

intfun(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=%d\n",a,b);
}
A) a=5,b=3 B) a=3,b=5 C)5,3 D)3,5
22. 以下程序运行后的输出结果是【】。

fun(int a, int b)
{
if(a>b) return a;
else return b;
}
main()
{
int *=3,y=8,z=6,r;
r=fun(fun(*,y),2*z);
printf("%d\n",r);
}
A) 3 B) 6 C) 8 D) 12
23. 以下程序的运行结果是【】。

void f(int a, int b)
{
int t;
t=a; a=b; b=t;
}
main()
{
int *=1, y=3, z=2;
if(*>y) f(*,y);
else if(y>z) f(*,z);
else f(*,z);
printf("%d,%d,%d\n",*,y,z);
}
A) 1,2,3 B) 3,1,2 C) 1,3,2 D) 2,3,1
24. 以下程序运行后的输出结果为【】。

int *f(int **, int *y)
{
if(**<*y) return *;
else return y;
}
main()
{
int a=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,8 B) 7,8,7 C) 8,7,7 D) 8,7,8
25. 以下程序的正确运行结果是【】。

#inclued<stdio.h>
main()
{
int k=4,m=1,p;
p=func(k,m);
printf("%d〞,p);
p=func(k,m);
printf("%d\n〞,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(*,y,z)=(*+z)/(y-z)+(y+2×z)/(*-2×z)的值,请将程
序补充完整。

#include<stdio.h>
float f(float *,float y)
{
float value;
value= 【1】;
return value;
}
main()
{
float *,y,z,sum;
scanf("%f%f%f",&*,&y,&z);
sum=f(*+z,y-z)+f(【2】);
printf("sum=%f\n",sum);
}
【1】A〕 */y B〕 */z C〕 (*+z)/(y-z) D〕 *+z/y-z
【2】A〕 y+2z,*-2z B〕 y+z,*-z C〕 *+z,y-z D〕 y+z*z,*-2*z
27. 以下程序的功能是根据输入的字母,在屏幕上显示出字符数组中首字符与其一样的字符
串,假设不存在,则显示"No find,good bye!〞,请将程序补充完整。

#include<stdio.h>
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。

请将程序补充完整。

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。

请将程序补充完整。

#include<stdio.h>
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=%d\n",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;
elsereturn(n+fun(n-1));
}
main()
{
int *;
scanf("%d",&*);
*=fun(*);
printf("%d\n",*);
}
程序执行时,假设输入10,程序的输出结果是【】。

A〕55 B〕54 C〕65 D〕45
31. 下面是一个计算1至m的阶乘并依次输出的程序。

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

#include<stdio.h>
double result=1;
factorial( int j)
{
result=result*j;
return;
}
main()
{
int m,i=0,*;
printf("Please enter an integer:");
scanf("%d",&m);
for(;i++<m;)
{
*=factorial(i);
printf("%d!=%.0f\n", 【】 );
}
}
A〕i,factorial(i) B〕i,* C〕j,* D〕i,result
32. 以下程序的功能是求任意两个整数a和b的最大公约数,并予以显示。

请将程序补充完
整。

#include<stdio.h>
#include<stdlib.h>
long codivisor(long n1,long n2)
{
long t;
while( n2!=0 )
{【1】; n1=n2; n2=t;}
return (【2】);
}
main()
{
long a,b,*;
printf("please input two numbers:");
scanf("%ld%ld",&a,&b);
*=codivisor(a,b);
printf("ma*imum common divisor of %ld and %ld is : %ld\n", a,b,*);
}
【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. 以下程序的功能是计算并显示一个指定行数的杨辉三角形〔形状如下〕,请将程序补充
完整。

1
11
1 2 1
1 3 3 1
1 4 6 4 1
1 5 10 10 5 1
程序:
#include<stdio.h>
#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<i;j++)
b[i][j]= 【3】 ;
for(i=0;i<n;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<N B〕i<=N C〕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>
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
进展查找。

请将程序补充完整。

#include<stdio.h>
#define N 15
bisearch(int a[N], int key)
{
int low=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 element increasing sequence: ", N);
for(i=0;i<N;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 %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. 如果程序及其运行结果显示如下,请将程序补充完整。

210 4 6
1 5
2 3
24 7 8
5 1 3 2
The value is 15.
程序:
#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];
return k;
}
main()
{
static int a[4][4]={ 【3】};
int i,j,k;
k=func(a,9);
for(i=0;i<4;i++)
{
for(j=0;j<4;j++)
if(a[i][j]!=0)
printf("%4d",a[i][j]);
if(a[i][4]!=0)
printf("\n");
}
printf("The value is %d\n",k);
}
【1】A〕int b[4][],kB〕int b[][4],k C〕int b[4,4],int k D〕int b[][4],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,3} 37.以下程序的功能是用二分法求方程f(*)=*41+*3+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>
float f(float *)
{
return (pow(*,41)+pow(*,3)+1);
}
float solv(float a,float b)
{
float m;
m=(a+b)/2;
while(f(m)*f(b)!=0)
{
if(【1】) a=m;
else b=m;
if(【2】) break;
m=(a+b)/2;
}
return m;
}
main()
{
float r;
r=solv(-1.0,-0.5);
printf("appro*imate solution of f(*)=0 is %f f(%f)=%.6f\n",r,r, 【3】);
}
【1】A〕f(m)*f(b)<0 B〕f(m)*f(b)>=0 C〕f(m)*f(b)<=0 D〕f(m)*f(b)>0 【2】
【3】A〕f(r) B〕f(m) C〕 r D〕m
38. 以下程序是选出能被3整除且至少有一位是5的所有三位正整数k(个位为a0,十位为
a1,百位为a2),打印出所有这样的数及其个数。

请将程序补充完整。

#include<stdio.h>
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=%d\n",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门课成绩的平均分,要求使用无返回值函数实现。

请将程
序补充完整。

#include<stdio.h>
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 %.2f\n",【3】 );
}
【1】A〕i<=10 B〕i++<10 C〕++i<10 D〕i<10
【2】A〕array[i-1] B〕array[i] C〕array[i--] D〕array[i++] 【3】A〕score[8] B〕score[0] C〕array[8] D〕score[9] 40. 以下程序用于输入不超过N个数的整数序列〔用-1作为输入完毕标志〕,然后统计出
从M1至M2各数在序列中出现的次数并显示输出。

请将程序补充完整。

#include<stdio.h>
#define N 100
#define M1 3
#define M2 7
main()
{
int a[N],c[M2-M1+1]={0},i,n=0,*=0;
printf("Please input a sequence of number(%d-%d) which is ended with -1:\n",M1,M2);
while(*!=-1)
{
scanf("%d",&*);
a[n]=*;
n++;
}
f(a,c,n);
printf("Repeating times of %d-%d in sequence of number is:\n",M1,M2);
for(i=0;i<=M2-M1;i++)
printf("%d:%d\n〞, 【1】);
printf("\n");
}
f(【2】)
{
int i;
for(i=0;i<n;i++)
if(a[i]>=M1 && a[i]<=M2)
【3】;
}
【1】A〕M1+i:c[M1+i] B〕M1+i+1:c[i]
C〕M1+i:c[i] D〕i:c[M1+i]
【2】A〕f(a[],c[],n) B〕f(int a[],int c[],int n)
C〕f(a,c,n) D〕f(int a[N],c[M2-M1+1],n)
【3】A〕c[a[i]]++ B〕c[a[i]-M2]++
C〕a[c[i]]++ D〕c[a[i]-M1]++
二.读程序写结果
1.
fun(int *,int y,int z)
{
z =***+y*y;
}
main ( )
{
int a=31;
fun (6,3,a);
printf ("%d", a);
}
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("%d\n",a);
}
3. 运行程序时,假设从键盘输入asd af aa z67〔回车〕,分析以下程序的输出结果。

#include <stdio.h>
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("%s\n",str);
}
4.
void swap(int *p1,int *p2)
{
int *t;
t=p1,p1=p2,p2=t;
printf("*p1=%d,*p2=%d\n",*p1,*p2);
}
main()
{
int *=10,y=20;
swap(&*,&y);
printf("*=%d,y=%d\n",*,y);
}
5.
#include <stdio.h>
void fun(int *s, int m, int n)
{
int t;
while(m<n)
{t=s[m]; s[m]=s[n]; s[n]=t; m++; n--;}
}
main()
{
Inta[5]={1,2,3,4,5},k;
fun(a,0,4);
for(k=0;k<5;k++)
printf("%d ",a[k]);
}
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("%d\n",fun(s));
}
7.
#include <stdio.h>
Intfun(int*)
{
int y;
if(*==0||*==1) return(3);
y=***-fun(*-2)
return y;
}
main()
{
int*,y;
*=fun(3);
y=fun(4);
printf("%d, %d\n", * ,y);
}
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 *;
fun(6,&*);
printf("%d\n",*);
}
三、填空题
1. 以下程序实现了计算*的n次方,请将程序填写完整。

float power(float *,int n)
{ int i;
float t=1;
for(i=1;i<=n;i++)
t=t**;
【1】;
}
main( )
{ float *,y;
int n;
scanf("%f,%d",&*,&n);
y=power(*,n);
printf("%\n",y);
}
2. 以下程序实现了求两个数的最大公约数,请将程序填写完整。

intdivisor(int a,int b)
{ int r;
r=a%b;
while(【2】)
{ a=b;b=r;r=a%b;}
return b;
}
void main()
{ int a,b,d,t;
scanf("%d %d",&a,&b);
if (a<b)
{ 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<t时返回负值。

请将函数填写完整。

my_cmp(char *s,char *t)
{
while(*s == *t)
{
if (【3】) return 0;
++s; ++t;
}
return 【4】;
}
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 <stdio.h>
#define N 80
int fun(int a[], int n)
{ int i,j=1;
for(i=1;i<n;i++)
if(a[j-1]【5】 a[i])
a[j++]=a[i];
return 【6】;
}
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<n;i++)
printf("%d 〞,a[i]);
n=fun(a,n);
printf("\nThe data after deleted: \n");
for(i=0; i<n;i++)
printf("%d 〞,a[i]);
}
四、编程题
1. 请用自定义函数的形式编程实现,求s=m!+n!+k!,m、n、k从键盘输入〔值均小于7〕。

2. 请用自定义函数的形式编程实现求10名学生1门课程成绩的平均分。

3. 请编写两个自定义函数,分别实现求两个整数的最大公约数和最小公倍数,并用主函数
调用这两个函数,输出结果〔两个整数由键盘输入得到〕。

4. 二阶Fibonacci数列:
请编写一个递归函数,实现求Fib(n)。

一、选择题
22.D 23.C 24.B 25.A 26.【1】A26.【2】D27.【1】B 27.【2】D27.【3】C28.【1】D 28.【2】C 29.【1】C29.【2】D 30.A31.D32.【1】B32.【2】A33.【1】C33.【2】B
33.【3】A34.【1】D34.【2】C35.【1】C35.【2】A35.【3】B
36.【1】D36.【2】B36.【3】A37.【1】A37.【2】B37.【3】A
38.【1】C38.【2】B38.【3】A39.【1】C39.【2】B39.【3】A
40.【1】C40.【2】B40.【3】D
二、读程序写结果:
1. 31
2. 15
3. asd af aa z67
4. *p1=20,*p2=10
*=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.
#include<stdio.h>
long fun(int *)
{ long y=1;
while(*>0)
{ y*=*;
*--; }
return(y);
}
main()
{int m,n,k;
printf("Please input m,n and k:\n");
scanf("%d,%d,%d",&m,&n,&k);
printf("%ld\n",fun(m)+fun(n)+fun(k));
}
2.
#include <stdio.h>
#define N 10
float average(float array[])
{int i=0;
float s=0;
for(i=0;i<N;i++)
s+=array[i];
s=s/N;
return s;
}
main()
{ float score[N],i;
float ave;
printf("Please input 10 scores:\n");
for(i=0;i<N;i++)
scanf("%f",&score[i]);
ave=average(score);
printf("\nThe average score is %.2f\n", ave);
}
3.
#include<stdio.h>
int divisor(int a,int b)
{ int r;
while((r=a%b)!=0)
{ a=b;
b=r;
}
return b;
}
int multiple(int a,int b)
{ int d;
d=divisor(a,b);
return a*b/d;
}
void main()
{ int a,b,c,d;
printf("intput (a,b): ");
scanf("%d,%d",&a,&b);
c=divisor(a,b);
d=multiple(a,b);
printf("\ndivisor=%d\t\tmultiple=%d",c,d);
}
4.
#include<stdio.h>
int fib(int n)
{ int p;
if(n==0) p=0;
else if(n==1) p=1;
-
else p=fib(n-1)+fib(n-2);
return p;
}
void main()
{ int n;
printf("Please input fib: ");
scanf("%d",&n);
printf("\n\nfibonacci=%d",fib(n)); }。

相关文档
最新文档