全国计算机等级考试C语言――编程题
1.m个人的成绩存放在score数组中,请编写函数fun,它的功能是:将低于平均分的人数作为函数值返回,将低于平均分的分数放在below所指的数组中。例如,当score数组中的数据为10、20、30、40、50、60、70、80、90时,函数返回的人数应该是4,below中的数据应为10、20、30、40。第一个for循环用来计算score数组中分数的总和,然后用aver/=m求出平均值,第二个循环用来找出小于平均分的元素,并放到数组below中,这里要注意j的递增方式。 #include
int fun(int score[],int m,int below[]) { int i,j=0,aver=0; for(i=0;i
int score[9]={10,20,30,40,50,60,70,80,90}; n=fun(score,9,below);
printf(\ for(i=0;i
for(i=1;i<1000;i++)
if(((i%7==0) || (i==0)) && !((i%7==0) && (i==0))) { a[m]=i;m+=1;} *n=m;} main( )
{ int aa[1000],n,k; clrscr( ); fun(aa,&n);
for(k=0;k if((k+1)==0) printf(\else printf(\ -1- 3.请编写函数void fun(int x,int pp[],int *n),它的功能是:求出能整除x且不是偶数的各整数,并按从小到大的顺序放在pp所指的数组中,这些除数的个数通过形参n返回。例如,若x中的值为30,则有4个数符合要求,它们是1,3,5,15。由于要求的数不能是偶数故编程时从1开始循环而步长为2这样正好保正i永远的奇数。这里也要注意存放结果的数组pp的下标变化方式。 #include void fun(int x,int pp[],int *n) { int i,j=0; for( i=1;i<=x;i=i+2) if(x%i==0) pp[j++]=i; *n=j; } main( ) { int x,aa[1000],n,i; printf(\ scanf(\ fun(x,aa,&n); for(i=0;i 4.请编写一个函数void fun(char *tt,int pp[]),统计在字符串中'a'到'z'26个字母各自出现的次数,并依次放在pp所指数组中。例如,当输入字符串abcdefgabcdeabc后,程序的输出结果应该是:3 3 3 2 2 1 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0本题采用的是字母的ASCII码值与数组pp下标的对应转换关系分别求出对应字母的个数。第一个for是给pp赋初值0,第二个for用于控制在字符串内从头到尾移动。由于字母'a'的ASCII码值为97而它的个数要放在pp[0]中,而'a'-97的值正好为0。 #include { char aa[1000]; int bb[26],k; clrscr( ); printf(\ scanf(\ fun(aa,bb); for(k=0;k<26;k++) printf(\ printf(\ 5.请编写一个函数void fun(int m,int k,int xx[]),该函数的功能是:将大于整数m且紧靠m 的k个素数存入xx所指的数组中。例如,若输入:17,5,则应输出:19,23,29,31,37。本题中的for循环用来判断一个数是否为素数, -2- 由于个数只能是k个所以用do-while循环来控制。 #include void fun(int m,int k,int xx[]) { int i,j=0,p=m+1; do { for( i=2;i =p) xx[j++]=p; p++;} while(j { int m,n,zz[1000]; printf(\ scanf(\ fun( m,n,zz); for(m=0;m 6.请编写一个函数void fun(char a[],char b[],int n),其功能是:删除一个字符串中指定下标的字符。其中,a指向原字符串,删除后的字符串存放在b所指的数组中,n中存放指定的下标。例如,输入一个字符串World,然后输入3,则调用该函数后的结果为Word。 #include void fun (char a[],char b [],int n) { int i,k=0; for(i=0;a[i]!='\\0';i++) if(i!=n) b[k++]=a[i]; b[k]='\\0'; } main( ) { FILE *wf ; char strl[LEN],str2[LEN]; int n; printf (\ gets(strl); printf (\ scanf (\ fun(strl,str2,n); printf (\ wf=fopen(\ fun(\ fprintf(wf,\ fclose(wf);} 7.请编写一个函数int fun(int *s,int t,int *k),用来求出数组的最大元素在数组中的下标并存放在k所指的存储 -3- 单元中。例如,输入如下整数:876 675 896 101 301 401 980 431 451 777则输出结果为:6,980。 #include int fun(int *s,int t,int *k) { int i,max; max=s[0]; for( i=0;i if(s[i]>max){ max=s[i];*k=i;} } main( ) { int a[10]={876,675,896,101,301, 401,980,431,451,777},k; fun(a,10,&k); printf(\ 8.编写函数fun,函数的功能是:根据以下公式计算s,计算结果作为函数值返回;n通过形参传入。s=1+1/(1+2)+1/(1+2+3)+.......+1/(1+2+3+4+......+n),例如:若n的值为11时,函数的值为1.833333。 #include for(i=0;i { int n;float s; printf(\ scanf(\ s=fun(n); printf(\ 9.编写函数fun,它的功能是:根据以下公式求P的值,结果由函数值带回。m与n为两个正整数且要求m>n。p=m!/n!(m-n)!。例如:m=12,n=8时,运行结果为495.000000。 #include float fun( int m,int n) { int i,j,k; long int t=1,s=1,p=1; float q; for(i=1;i<=m;i++) t*=i; for(j=1;j<=n;j++) s*=j; -4- for(k=1;k<=m-n;k++) p*=k; q=(float)t/s/p; return q;} main( ) { printf(\ 10.编写函数fun,它的功能是:利用以下所示的简单迭代方法求方程cos(x)-x=0的一个实根。 Xn+1=cos(Xn) 迭代步骤如下: (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。 #include x1=cos(x0);} while( fabs(x0-x1)>1e-006); return x1;} main( ) { printf(\ 11.下列程序定义了N×N的二维数组,并在主函数中自动赋值。请编写函数fun(int a[][N]),该函数的功能是:使数组左下半三角元素中的值全部置成0。例如:a数组中的值为该题的关键是如何表示出左下半角的元素,当从上往下到第i行时只有左边的i个元素要置为0(每行总是如此)。用外层for来控制行而内嵌的for来控制每行的左边元素,故而在内嵌for中j最大只能循环到i(即表示出第i行左边的i个元素)。 1 9 7 0 9 7 a= 2 3 8 0 0 8 4 5 6 ,则返回主程序后a数组中的值应为 0 0 0 。 #include -5-