大橙子网站建设,新征程启航

为企业提供网站建设、域名注册、服务器等服务

c语言机考函数试题,c语言程序设计考试题机考

c语言函数习题

1、 函数调用:strcat(strcpy(str1,str2),str3)的功能是________。

创新互联公司专注为客户提供全方位的互联网综合服务,包含不限于网站建设、成都网站制作、万秀网络推广、小程序开发、万秀网络营销、万秀企业策划、万秀品牌公关、搜索引擎seo、人物专访、企业宣传片、企业代运营等,从售前售中售后,我们都将竭诚为您服务,您的肯定,是我们最大的嘉奖;创新互联公司为所有大学生创业者提供万秀建站搭建服务,24小时服务热线:18980820575,官方网址:www.cdcxhl.com

C) 将串str2复制到串str1中后再将串str3连接到串str1之后

2、 若有以下调用语句,则正确的fun函数首部是

main()

{ ∶

int a;float x;

fun(x,a);

}

B) void fun(float a,int x)

3、 有如下程序

int func(int a,int b)

{ return(a+b); }

main()

{ int x=2,y=5,z=8,r;

r=func(func(x,y),z);

printf("%d\n",r); }

该程序的输出结果是__________。

D) 15

4、 函数pi的功能是根据以下近似公式求π值:

(π*π)/6=1+1/(2*2)+1/(3*3)+……+1/(n*n)

请你在下面程序中的划线部分填入________,完成求π的功能。

#include "math.h"

double pi(long n)

{ double s=0.0; long i;

for(i=1;i=n;i++) s=s+________;

return (sqrt(6*s)); }

A) 1.0/i/i

5、 在调用函数时,如果实参是简单变量,它与对应形参之间的数据传递

方式是________。

B) 单向值传递

6、 对于C语言的函数,下列叙述中正确的是________。

A) 函数的定义不能嵌套,但函数调用可以嵌套 (这答案有待斟酌)

7、 函数f的功能是:测定字符串的长度,空白处应填入________。

int f(char s[ ])

{ int i=0;

while(s[i]!='\0') i++;

return (________); }

main( )

{ printf("%d\n",f("goodbye!")); }

B) i

8、 若主调用函数类型为double,被调用函数定义中没有进行函数类型

说明,而return语句中的表达式类型为float型,则被调函数返回

值的类型是________。

C) double 型

9、 以下叙述中,错误的是________。

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

10、 以下叙述中,不正确的是________。

B) 在main函数体内定义的变量是全局变量

c语言上机试题

1.m个人的成绩存放在score数组中,请编写函数fun,它的功能是:将低于平均分的人作为函数值返回,将低于平均分的分数放在below所指定的函数中。

1.int fun(int score[],int m,int below[])

{int i,k=0,aver=0;

for(i-0;im;i++)

aver+=score[i];

aver/=m;

for(i=0,im;i++)

if(score[i]aver)

{below[k]=score[i];

k++;}

return k;}

2.请编写函数fun,它的功能是:求出1到100之内能北7或者11整除,但不能同时北7和11整除的所有证书,并将他们放在a所指的数组中,通过n返回这些数的个数。

2.void fun(int *a,int *n)

{int i,j=0;

for(i=2;i1000;i++)

if((i%7==0//i%11==0))i%77!=0)

a[j++]=i;

*n=j;}

3.请编写函数void fun(int x,int pp[],int *n),它的功能是:求出能整除x且不是偶数的各整数,并按从小到大的顺序放在pp所指的数组中,这些除数的个数通过形参n返回。

3. void fun(int x, int pp[],int *n)

{int i=1,j=0,k=0,*t=pp;

for(i=0;i=x;i++)

if(i%2!=0)

{t[j]=i;

j++;}

for(i=0;ij;i++)

if(x%t[i]==0)

{pp[k]=t[i];

k++;}

*n=k;}

4.请编写一个函数void fun(char *tt,int pp[]),统计在tt字符中"a"到"z"26各字母各自出现的次数,并依次放在pp所指的数组中。

4. void fun(char *tt,int pp[])

{int i;

for(i=0;i26;i++)

pp[i]=0;

while (*tt)

{switch(*tt)

{case'a':pp[0]++;break;

case'b':pp[1]++;break;

case'c':pp[2]++;break;

case'd':pp[3]++;break;

case'e':pp[4]++;break;

case'f':pp[5]++;break;

case'g':pp[6]++;break;

case'h':pp[7]++;break;

case'i':pp[8]++;break;

case'j':pp[9]++;break;

case'k':pp[10]++;break;

case'l':pp[11]++;break;

case'm':pp[12]++;break;

case'n':pp[13]++;break;

case'o':pp[14]++;break;

case'p':pp[15]++;break;

case'q':pp[16]++;break;

case'r':pp[17]++;break;

case's':pp[18]++;break;

case't':pp[19]++;break;

case'u':pp[20]++;break;

case'v':pp[21]++;break;

case'w':pp[22]++;break;

case'x':pp[23]++;break;

case'y':pp[24]++;break;

case'z':pp[25]++;break;}

tt++;}

}

5.请编写一个函数void fun(int m,int k,int xx[]),该函数的功能是:将大于整数m且紧靠m的k各素数存入xx所指的数组中。

5. void fun(int m,int k,int xx[])

{int g=0,i,j,flag=1;

for(i=m+1;im*m;i++)

{for(j=2;ji;j++)

{if (i%j!=0)

flag=1;

else

{flag=0;

break;}

}

if (flag==1j=i)

{if (k0)

{xx[g++]=i;

k--;}

else

break;}}}

6.请编写一个函数void fun(char a[],char[],int n),其功能是:删除以各字符串中指定下标的字符。其中,a指向原字符串,删除后的字符串存放在b所指的数组中,n中存放指定的下标。

6. void fun(char a[],char b[],int n)

{int i,j=0;

for (i=0;iLEN;i++)

if(i!=n)

{b[j]=a[i];

j++;}

b[j]='\0';}

7.请编写一个函数int fun(int *s,int t,int *k),用来求除数组的最大元素在数组中的下标并存放在k所指的储存单元中。

7. void fun(int *s,int t,int*k)

{int i,max;

max=s[0];

for (i=0;it;i++)

if (s[i]max)

{max=s[i];

*k=i; }}

8.编写函数fun,功能是:根据以下攻势计算s,计算结果作为函数值返回;n通过形参传入。s=1+1/(1+2)+1/(1+2+3)+.......+1/(1+2+3+4+......+n)

8. float fun(int n)

{int i;

float s=1.0,t=1.0;

for (i=2;i=n;i++)

{t=t+i;

s=s+1/t;}

return s;}

9.编写一个函数fun,它的功能是:根据以下公式求P的值,结果由函数值带回。m与n为两个正整数,且要求mn。 p=m!/n!(m-n)!

9. p=m!/n!(m-n)!

float fun(int m,int n)

{float p,t=1.0;

int i;

for (i=1;i=m;i++)

t=t*i;

p=t;

for (t=1.0,i=1;i=n;i++)

t=t*i;

p=p/t;

for(t=1.0,i=1;im-n;i++)

t=t*i;

p=p/t;

return p;}

10.编写函数fun,它的功能是:利用以下的简单迭代方法求方程cos(x)-x=0的一个实根。

迭代步骤如下:(1)取x1初值为0.0; (2)x0=x1,把x1的值赋各x0;

(3)x1=cos(x0),求出一个新的x1;

(4)若x0-x1的绝对值小于0.000001,则执行步骤(5),否则执行步骤(2);

(5)所求x1就是方程cos(x)-x=0的一个实根,作为函数值返回。

程序将输出Root=0.739085。

10. folat fun()

{float x1=0.0,x0;

do

{x0=x1;

x1=cos(x0); }

while (fabs(x0-x1)=1e-6);

return x1;}

11.下列程序定义了N×N的二维数组,并在主函数中自动赋值。请编写函数 fun(int a[][N]),该函数的功能是:使数组左下半三角元素中的值全部置成0。

11. int fun(int a[][N])

{int i,j;

for(i=0;iN;i++)

for(j=0;ji;j++)

a[i][j]=0;}

12.下列程序定义了N×N的二维数组,并在主函数中赋值。请编写函数fun,函数的功能使求出数组周边元素的平均值并作为函数值返回给主函数中的s。

12.double fun (int w[][N])

{int i,j,k=0;

double s=0.0;

for (j=0;jN;j++)

{s+=w[0][j];

k++;}

for (j=0;jN;j++)

{s+=w[N-1][j];

k++;}

for (i=1;i=N-2;i++)

{s+=w[i][0];

k++;}

return s/=k;}

13.请编写一个函数void fun(int tt[M][N],int pp[N]),tt指向一个M行N列的二维函数组,求出二维函数组每列中最小元素,并依次放入pp所指定一维数组中。二维数组中的数已在主函数中赋予。

13. void fun(int tt[M][N],int pp[N])

{int i,j,min;

for (j=0;jN;j++)

{min=tt[0][j];

for (i=0;iM;i++)

{if (tt[i][j]min)

min=tt[i][j];}

pp[j]=min;}}

14.请别写函数fun,函数的功能使求出二维数组周边元素之和,作为函数值返回。二维数组中的值在主函数中赋予。

14. int fun (int a[M][N])

{int i,j,s=0;

for (j=0;jN;j++)

{s+=a[0][j];

s+=a[M-1][j];}

for (i=1;i=M-2;i++)

{s+=a[i][0];

s+=a[i][N-1];}

return s;}

15.请编写一个函数unsigned fun(unsigned w),w使一个大于10的无符号整数,若w使n(n≥2)位的整数,则函数求出w后n-1位的数作为函数值返回。

15. unsigned fun(unsigned w)

{unsigned t,s=0,s1=1,p=0;

t=w;

while(t10)

{if(t/10)

p=t%10;

s=s+p*s1;

s1=s1*10;

t=t/10; }

return s;}

16.请编写一个函数float fun(double h),函数的功能使对变量h中的值保留2位小树,并对第三位进行四舍五入(规定h中的值位正数)。

16. float fun (float h)

{long t;

float s;

h=h*1000;

t=(h+5)/10;

s=(float)t/100.0;

return s;}

17.请编写一个函数fun(char *s),该函数的功能使把字符串中的内容拟置。

17. void fun(char *s)

{char ch;

int i,m,n;

i=0;

m=n=strlen(s)-1;

while(i(n+1)/2)

{ch=s[i];

s[i]=s[m];

s[m]=ch;

i++;

m--;}}

18.编写程序,实现矩阵(3行3列)的转置(即行列互换)。

18. void fun(int array[3][3])

{int i,j,temp;

for (i=0;i3;i++)

{temp=array[i][j];

array[i][j]=array[j][i];

array[j][i]=temp; }}

19.编写函数fun,该函数的功能是:从字符中删除指定的字符,同一字母的大、小写按不同字符处理。

19. void fun(char s[],int c)

{int i=0;

char*p;

p=s;

while(*p)

{if(*p!=c)

{s[i]=*p;

i++;}

p++;}

s[i]='\0';}

20.编写函数int fun(int lim,int aa[MAX]),该函数的功能是求出小于或等于lim的所有素数并放在aa数组中,该函数返回所求的素数的个数。

20. int fun(int lim,int aa[MAX])

{int k=0,i,j;

for(i=lim;i1;i--)

{for(j=2;ji;j++)

if(i%j==0)

break;

else

continue;

if(j=i)

{aa[k]=i;

k++;}}

return k++;}

21.请编写函数fun,对长度位7个字符的字符串,除首尾字符外,将其余5个字符按ASCII码降序排列。

21.void fun(char *s,int num)

{char t;

int i,j;

for (i=1;inum-2;i++)

for (j=i+1;jnum-1;j++)

if(s[i]s[j])

{t=s[i];

s[i]=s[j];

s[j]=t;}}

22.N名学生的成绩已在主函数中放入一个带头节点的链表结构中,h指向链表的头节点。请编写函数fun,它的功能是:找出学生的最高分,由函数值返回。

22. double fun (STREC *h)

{ double max;

STREC *q=h;

max=h-s;

do

{if(q-smax)

max=q-s;

q=q-next; }

while(q!=0);

return max;}

23.请编写函数fun,该函数的功能是:判断字符串是否为回文?若是则函数返回1,主函数中输出YES,否则返回0,主函数中输出NO。回文是指顺读和倒读都是一样的字符串。

23. int fun(char *str)

{int i,n=0,fg=1;

char *p=str;

while (*p)

{n++;

p++;}

for (i=0;in/2;i++)

if (str[i]==str[n-1-i]);

else

{fg=0;

break;}

return fg;}

24.请编写一个函数fun,它的功能是:将一个字符串转换为一个整数(不得调用C语言提供的将字符串转换为整数的函数)。

24. long fun(char *p)

{long s=0,t;

int i=0,j,n=strlen(p),k,s1;

if(p[0]=='-')

i++;

for(j=i;j=n-1;j++)

{t=p[j]-'0';

s1=10;

for (k=j;kn-1;k++)

t*=s1;

s+=t; }

if(p[0]=='-')

return -s;

else

return s;}

25.请编写一个函数fun,它的功能是:比较两个字符串的长度,(不得调用C语言提供的求字符串长度的函数),函数返回较长的字符串。若两个字符串长度相同,则返回第一个字符串。

25. char *fun(char *s,char *t)

{char *p,*t1=t,*s1=s;

int n=0,m=0;

while(*s1)

{n++;

s1++;}

while(*t1)

{m++;

t1++;}

if(n=m)

p=s;

else

p=t;

return p;}

26.请编写一个函数fun,它的功能是:根据以下公式求X的值(要求满足精度0.0005,即某项小于0.0005时停止迭代):

X/2=1+1/3+1×2/3×5+1×2×3/3×5×7+1×2×3×4/3×5×7×9+...+1×2×3×...×n/3×5×7×(2n+1)

程序运行后,如果输入精度0.0005,则程序输出为3.14...。

26. double fun(double eps)

{double s;

float n,t,pi;

t=1;pi=0;n=1.0;s=1.0;

while((fabs(s))=eps)

{pi+=s;

t=n/(2*n+1);

s*=t;

n++;}

pi=pi*2;

return pi;}

27.请编写一个函数fun,它的功能是:求除1到m之内(含m)能北7或11整除的所有整数放在数组a中,通过n返回这些数的个数。

27.void fun(int m,int *a,int *n)

{int i,j;*n=0;

for(i=1;i=m;i++)

if(i%7==0//i%11==0)

{a[j]=i;

j++;}

*n=j;}

28.请编写一个函数fun,它的功能是:找出一维整型数组元素中最大的值和它所在的下标,最大的值和它所在的下标通过形参传回。数组元素中的值已在主函数中赋予。主函数中x是数组名,n 是x中的数据个数,max存放最大值,index存放最大值所在元素的下标。

28. void fun(int a[],int n, int *max,int *d)

{int i;

*max=a[0];

*d=0;

for(i=0;in;i++)

if(a[i]*max)

{*max=a[i];

*d=i;}}

29.请编写一个函数fun,它的功能是:将ss所指字符串中所有下标为奇数位置上的字母转换为大写(若该位置上不是字母,则不转换)。

29. void fun(char *ss)

{int i,n;

n=strlen(ss);

for(i=1;in;i+=2;)

if(ss[i]='a'ss[i]='z')

ss[i]=ss[i]-32;}

30.请编写一个函数fun,它的功能是:求除一个2×M整型二维数组中最大元素的值,并将此值返回调用函数。

30. int fun(int a[][M])

{int i,j,max;

max=a[0][0];

for(i=0;i2;i++)

for(j=0;jM;j++)

if(a[i][j]max)

max=a[i][j];

return max;}

31.请编写函数fun,其功能是:将s所指字符串中除了下标为偶数、同时ASCII值也为偶数的字符外,其余的全都删除;串中剩余字符所形成的一个新串放在t所指的一个数组中。

31. void fun(char *s,char t[])

{int i,j,n;

n=strlen(s);

for(i=0;in;i++)

if(i%2==0s[i]%2==0)

{t[j]=s[j];

j++;}

t[j]='\0';}

32.请编写函数fun,其功能是:将s所指字符串中除了下标为奇数、同时ASCII值也为奇数的字符之外,其余的所有字符都删除,串中剩余字符所形成的一个新串放在t所指的一个数组中。

32. void fun(char *s,char t[])

{int i,j=0,n;

n=strlen(s);

for(i=0;in;i++)

if(i%2!=0s[i]%2!=0)

{t[j]=s[j];

j++;}

t[j]='\0';}

33.假定输入的字符串中只包含字母和*号。请编写函数fun,它的功能是:使字符串中尾部的*号不得多于n个;若多于n个,则删除多于的*号;若少于或等于n个,则什么也不做,字符串中间和前面的*号不删除。

33. void fun(char *a,int n)

{int i=0,k=0;

char *p,*t;

p=t=a;

while(*t)

t++;

t--;

while(*t--'*')

{k++;

t--;}

t++;

if(kn)

{while(*ppt+n)

{a[i]=*p;

i++;

p++;}

a[i]='\0'; }}

34.学生的记录由学号和成绩组成,N名学生的数据已在主函数中放入结构体数组s中,请编写函数fun,它的功能使:把分数最高的学生数据放在h所指的数组中,注意:分数最高的学生可能不止一个,函数返回分数最高的学生的人数。

34. int fun(STREC*a,STREC *b)

{int i,j=0,max;

max=a[0].s;

for(i=0;iN;i++)

if(a[i].s==max)

{*(b+j)=a[i];

j++;

n++;}

return n;}

35.请编写一个函数,用来删除字符串中的所有空格。

35. void fun(char *str)

{int i=0;

char *p=str;

while(*p)

{if(*p!='')

{str[i]=*p;

i++;}

p++;}

str[i]='\0';}

36.假定输入的字符串中只包含字母和*号。请编写函数fun,它的功能是:将字符串中的前导*号全部移到字符串的尾部。

36. void fun(char *a)

{int i=0,n=0;

char *p;

p=a;

while (*p=='*')

{n++;

p++;}

while (*p)

{a[i]=*p;

i++;

p++;}

while(n!=0)

{a[i]='*';

i++;

i--;}

a[i]='\0';}

37.某学生的记录由学号、8门课程成绩和平均分组成,学号和8门课程的成绩已在主函数中给出。请编写函数fun,它的功能是:求出该学生的平均分放在记录的ave成员中。请自己定义正确的形参。

37. void fun(STREC *p)

{double av=0.0;

int i;

for(i=0;iN;i++)

av+=p-s[i];

av/=N;

p-ave=av;}

38.请编写函数fun,它的功能是:求出ss所指字符串中指定字符的个数,并返回此值。

38. int fun(char *ss,char c)

{int n=0;

while(*ss)

{if(*ss==c)

n++;

ss++;}

return n;}

39.请编写函数fun,该函数的功能是:移动一维数组中的内容,若数组中由n个整数,要求把下标从0到p(p小于等于n-1)的数组元素平移到数组的最后。

39. void fun(int *w,int p,int n)

{int b[N],i,j=0;

for(i=0;i=p;i++)

b[i]=w[i];

for(i=p+1;in;i++)

{w[j]=w[i];

j++;}

for(i=0;i=p;i++)

{w[j]=b[i];

j++;}}

40.请编写函数fun,该函数的功能是移动字符串中内容,移动的规则如下:把第1到第m个字符,平移到字符串的最后,把第m+1到最后的字符移到字符串的前部。

40.void fun(char *w,int m)

{char b[N];

int i,j=0;

for(i=0;im;i++)

{b[j]=w[i];

j++;}

for(i=0;istrlen(w)-m;i++)

w[i]=w[i+m];

for(j=0;jm;j++)

{w[i]=b[j];

i++;}

w[i]='\0';}

41.请编写函数fun,该函数的功能是:将M行N列的二维数组中的字符数据,按列的顺序依次放到一个字符串中。

41. void fun(char (*s)[N],char *b)

{int i,j,k=0;

for(j=0;jn;j++)

for(i=0;iM;i++)

{b[k]=*(*(s+i)+j)

k++;}

b[k]='\0';}

42.下列程序定义了N×N的二维数组,并在主函数中自动赋值。请编写函数fun(int a[][N],int m),该函数的功能是:将数组右上半三角元素中的值乘以m。

42. void fun(int a[][N],int m)

{int i,j;

for(j=0;jN;j++)

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

a[i][j]=a[i][j]*m;}

43.编写一个函数,从传入的num个字符串中找出一个最长的一个字符串,并通过形参指针max传回该串地址(用****作为结束输入的标志)。

43. char *fun(char (*a)[81],int num)

{int i;

char *max;

max=a[0];

for(i=0;inum;i++)

if(strlen(max)strlen(a[i]))

max=a[i];

return max;}

44.编写一个函数,该函数可以统计一个长度为2的字符串在另一个字符串中出现的次数。

44. int fun(char *str,char *substr)

{int n;

char *p,*r;

n=0;

while(*str)

{p=str;

r=substr;

while(*r)

if(*r==*p)

{r++;

p++;}

else

break;

if(*r=='\0')

n++;

str++;}

return n;}

45.假定输入的字符串中只包含字母和*号。请编写函数fun,它的功能是:只删除字符串前导和尾部的*号,串中字母之间的*号都不删除。形参n 给出了字符串的长度,形参h给出了字符串中前导*号的个数,形参e给出了字符串中最后的*个数。在编写时不得使用C语言给提供得字符串函数。

45.void fun(char *a,int n,int h,int e)

{int i=0;

char *p;

for(p=a+h;pa+n-e;p++)

{*(a+i)=*p;

i++;}

*(a+i)='\0';}

46.学生得记录由学号和成绩组称个,N名大学生得数据已在主函数中放入结构体数组s中,请编写函数fun,它的功能时:按分数的高低排列学生的记录,高分在前。

46. void fun(STREC a[])

{int i,j;

STREC t;

for(i=0;iN-1;i++)

for(j=i;sN;j++)

if(a[i].sa[j].s)

{t=a[i];

a[i]=a[j];

a[j]=t; }}

47.请编写一个函数void fun(char *ss),其功能时:将字符串ss中所有下标为奇数位置上的字母转换为大写(若位置上不是字母,则不转换)。

47. void fun(char *ss)

{int i,n=0;

char *p=ss;

while(*p)

{n++;

p++;}

for (i=0;in;i++)

if ((ss[i]='a'ss[i]='z')

ss[i]=ss[i]-32;

ss[i]='\0';}

48.请编写函数fun,其功能是:将两个两位数的正整数a,b合并成一个整数放在c中。合并的方式是:将a数的十位和个位依次放在c数的千位和十位上,b数的十位和个位数依次放在c数的百位和个位上。

48. void fun(int a,int b,long *c)

{*c=(a/10)*1000+(b/10)*100+(a%10)*10+b%10;}

49.请编写函数fun,其功能是:将s所指字符串中下标位偶数同时ASCII值为奇数的字符删除,s中剩余的字符形成的新串放在t所指的数组中。

49. void fun(char *s,char t[])

{int i,j=0,n=strlen(s);

for(i=0;in;i++)

if(i%2==0s[i]%2!=0)

else

{f[j]=s[i];

j++;}

t[j]='\0';}

50.已知学生的记录是由学号和学习成绩构成,N名学生的数据已存入结构体数组中。请编写函数fun,该函数的功能是:找出成绩最高的学生记录,通过形参返回主函数(规定只有一个最高分)。

50. void fun(STU a[],STU *s)

{int i,max;

max=a[0].s;

for (i=0;iN;i++)

if(a[i].smax)

{max=a[i].s;

*s=a[i];}}

51.请编写函数fun,其功能是:将所有大于1小于整数m的非素数存入xx所指的数组中,非素数的个数通过k传回。

51. void fun(int m,int *k,int xx[])

{int i,j;

int t=0;

for(i=2;im;i++)

{j=2;

while(ji)

{if(i%j==0)

{xx[t]=i;

t++;

break;}

j++;}

*k=t;}}

52.编写一个函数fun,它的功能是:实现两个字符串的连接(不使用库函数strcat),即把p2所指的字符串连接到p1所指的字符串后。

52. void fun(char p1[],char p2[])

{int i=0,n=0;

char *p=p1,*q=p2;

while (*p)

{p++;

n++;}

i=n;

while(*p)

{p1[i]=*q;

q++;

i++;}

p1[i]='\0';}

53.请编写函数fun,该函数的功能是:实现B=A+A',即把矩阵A加上A的转置,存放在矩阵B中。计算结果在main函数中输出。

53. void fun(int a[3][3],int b[3][3])

{int i,j,at[3][3];

for(i=0;i=2;i++)

for(j=0;j=2;j++)

at[i][j]=a[j][i];

for(i=0;i3;i++)

for(j=0;j3;j++)

b[i][j]=a[i][j]+at[i][j];}

54.学生的记录由学号和成绩组称个,N名学生的数据已在主函数中放入结构体数组s中,请编写函数fun,它的功能是:把低于平均分的学生数据放在b所指的数组中,低于平均分的学生人数通过形参n传回,平均分通过函数值返回。

54. double fun(STREC *a, STREC *b,int *n)

{double aver=0.0;

int i,j=0;

*n=0;

for (i=0;iN;i++)

aver+=a[i].s;

aver/=N;

for(i=0;iN;i++)

if(a[i].saver)

{b[j]=a[i];

(*n)++;

j++; }

return aver;}

大一c语言上机考试题

#include stdio.h

int fun(int n){

int i;

if(n2  !(n1) || n2)

return 0;

for(i=3;i*i=n;i+=2)

if(!(n%i))

return 0;

return 1;

}

int main(void){

int s[8],i;

printf("Input 8 integers...\n");

for(i=0;i8;scanf("%d",s+i++));

printf("The prime Numbers:\n");

for(i=0;i8;i++)

if(fun(s[i]))

printf("%d ",s[i]);

printf("\nThe sum Numbers:\n"); 

for(i=0;i8;i++)

if(!fun(s[i]))

printf("%d ",s[i]);

printf("\n"); 

return 0;

}

国家开放大学 c语言机试题

楼上的你这样是想把我笑死,好继承我的小树林吗?哈哈哈敷衍也不要这样随便打字出来吧~

好了好了回归正题,希望没有太晚哈哈,随便在电大题酷这个小程序上搜了一些题,不知道适不适合你呢?这个小程序还挺好用的,我觉得电大学生都应该人手备一个,如果你还想要其他的,建议你去这个小程序上搜其他的哦,希望能够帮到你哦~~~~~~~~~~~~~~~~~~~~~

1 单选 C语言中函数返回值的类型是由 ( A ) 决定的.

A. 函数定义时指定的类型

B. return语句中的表达式类型

C. 调用该函数时的实参的数据类型

D. 形参的数据类型

2 单选 在函数调用时,以下说法正确的是:( B )。

A. 函数调用后必须带回返回值

B. 实际参数和形式参数可以同名

C. 函数间的数据传递不可以使用全局变量

D. 主调函数和被调函数总是在同一个文件里

3 单选 语句int *p;说明了( C )。

A. p是指向一维数组的指针

B. p是指向函数的指针

C. p是指向int型数据的指针

D. p是函数名,该函数返回一指向int型数据的指针

4 单选 下列指针的定义不正确的定义是( A )。

A. int *p=i,i;

B. int *p,i;

C. int i,*p=i;

D. int i,*p;

5 单选 有语句:int a[10],;则( B )是对指针变量p的正确定义和初始化。

A. int p=*a;

B. int *p=a;

C. int p=a;

D. int *p=a;

6 单选 若有说明语句“int a[5],*p=a;”,则对数组元素的正确引用是:( C )。

A. a[p]

B. p[a]

C. *(p+2)

D. p+2

7 单选

有如下程序

int a[10]={1,2,3,4,5,6,7,8,9,10},*p=a;

则数值为9的表达式是:( B )。

A. *p+9

B. *(p+8)

C. *p+=9

D. p+8

8 单选 被调函数调用结束后,返回到 :( D )。

A. 主调函数中该被调函数调用语句处

B. 主函数中该被调函数调用语句处

C. 主调函数中该被调函数调用语句的前一语句

D. 主调函数中该被调函数调用语句的后一语句

9 单选 能把函数处理结果的两个数据返回给主调函数,在下面的方法中不正确的是:( A )。

A. return 这两个数

B. 形参用两个元素的数组

C. 形参用两个这种数据类型的指针

D. 用两个全局变量

10 单选 下列各语句定义了数组,其中哪一个是不正确的( C )。

A. char a[3][10]={"China","American","Asia"};

B. int x[2][2]={1,2,3,4};

C. float x[2][ ]={1,2,4,6,8,10};

D. int m[][3]={1,2,3,4,5,6};

11 单选 # include stdio.hint test(int b){ b*=10;printf(“b=%d ”,b);return b/2;}void main(){ int b=60;b=test(b);printf(“b=%d ”,b);}程序的运行结果是:( D )。

A. b=10 b=60

B. b=10 b=30

C. b=300 b=600

D. b=600 b=300

12 单选 如果一个函数作为表达式被调用,则该函数必须是 ( A )。

A. 有返回值的函数

B. 无返回值的函数

C. 有参函数

D. 无参函数

13 单选 C语言程序由函数组成,它的( B )。

A. 主函数必须在其它函数之前,函数内可以嵌套定义函数。

B. 主函数可以在其它函数之后,函数内不可以嵌套定义函数。

C. 主函数必须在其它函数之前,函数内不可以嵌套定义函数。

D. 主函数可以在其它函数之后,函数内可以嵌套定义函数。

14 单选 下列表达式中,与下标引用a[k]等效的是:( A )。

A. *(a+k)

B. a+k

C. *a+k

D. a+*k

15 单选 下列结论中,只有( D )是不正确的。

A. C语言不允许函数嵌套定义。

B. C语言允许函数嵌套调用。

C. C语言中允许函数递归调用。

D. C语言所有函数都可以相互调用,包括调用main。


文章标题:c语言机考函数试题,c语言程序设计考试题机考
转载注明:http://dzwzjz.com/article/dsspghp.html
在线咨询
服务热线
服务热线:028-86922220
TOP