预览加载中,请您耐心等待几秒...
1/6
2/6
3/6
4/6
5/6
6/6

在线预览结束,喜欢就下载吧,查找使用更方便

如果您无法下载资料,请参考说明:

1、部分资料下载需要金币,请确保您的账户上有足够的金币

2、已购买过的文档,再次下载不重复扣费

3、资料包下载后请先用软件解压,在使用对应软件打开

C语言上机编程期末复习题 1:第1题m个人的成绩存放在score数组中,请编写函数fun,它的功能是:将低于平均分的人作为函数值返回,将低于平均分的分数放在below所指定的函数中。 intfun(intscore[],intm,intbelow[]) { inti,k=0,aver=0; for(i=0;i<m;i++) aver+=score[i]; aver/=m; for(i=0;i<m;i++) if(score[i]<aver) { below[k]=score[i]; k++; } returnk; } 2:第2题请编写函数fun,它的功能是:求出1到100之内能北7或者11整除,但不能同时北7和11整除的所有整数,并将他们放在a所指的数组中,通过n返回这些数的个数。 voidfun(int*a,int*n) { inti,j=0; for(i=2;i<1000;i++) if((i%7==0||i%11==0)&&i%77!=0) a[j++]=i; *n=j; } 5:第5题请编写一个函数voidfun(intm,intk,intxx[]),该函数的功能是:将大于整数m且紧靠m的k各素数存入xx所指的数组中。 voidfun(intm,intk,intxx[]) { intg=0,I,j,flag=1; for(i=m+1;i<m*m;i++) { for(j=0;j<I;j++) { if(i%j!=0) flag=1; else { flag=0; break; } } if(flag==1&&j>=i) { if(k>=0) { xx[g++]=i; k--; } else break; } } } 7:第7题请编写一个函数intfun(int*s,intt,int*k),用来求除数组的最大元素在数组中的下标并存放在k所指的储存单元中。 voidfun(int*s,intt,int*k) { intI,max; max=s[0]; for(i=0;i<t;i++) if(s[i]>max) { max=s[i]; *k=I; } } 8:第8题编写函数fun,功能是:根据以下公式计算s,计算结果作为函数值返回;n通过形参传入。S=1+1/(1+2)+1/(1+2+3)+…….+1/(1+2+3+4+……+n) floatfun(intn) { inti; floats=1.0,t=1.0; for(i=2;i<=n;i++) { t=t+i; s=s+1/t; } returns; } 9:第9题编写一个函数fun,它的功能是:根据以下公式求p的值,结果由函数值带回。M与n为两个正整数,且要求m>n。p=m!/n!(m-n)! floatfun(intm,intn) { floatp,t=1.0; intI; 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;i<=m-n;i++) t=t*I; p=p/t; returnp; } 11:第11题下列程序定义了n×n的二维数组,并在主函数中自动赋值。请编写函数fun(inta[][n]),该函数的功能是:使数组左下半三角元素中的值全部置成0。 intfun(inta[][N]) { intI,j; for(i=0;i<N;i++) for(j=0;j<=I;j++) a[i][j]=0; } 13:第13题请编写一个函数voidfun(inttt[m][n],intpp[n]),tt指向一个m行n列的二维函数组,求出二维函数组每列中最小元素,并依次放入pp所指定一维数组中。二维数组中的数已在主函数中赋予。 voidfun(inttt[M][N],intpp[N]) { intI,j,min; for(j=0;j<N;j++) { min=tt[0][j]; for(i=0;i<M;i++) { if(tt[i][j]<min) min=tt[i][j]; } pp[j]=min; } } 17:第17题请编写一个函数fun(char*s),该函数的功能使把字符串中的内容逆置。 voidfun(char*s) { charch; intI,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:第18题编写程序,实现矩阵(3行3列)的转置(即行列互换)。 voidfun(intarray[3][3]) { intI,j,temp; for(i=0;i<3;i++) for(j=0;j<I,j++) { t