全国计算机二级C上机 编程题

2019-03-29 14:34

全国计算机等级考试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 #include #include

int fun(int score[],int m,int below[]) { int i,j=0,aver=0; for(i=0;i{ int i,n,below[9];

int score[9]={10,20,30,40,50,60,70,80,90}; n=fun(score,9,below);

printf(\ for(i=0;i #include void fun(int *a,int *n) { int i,m=0;

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 #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 #include void fun(char *tt,int pp[]) { int i; for(i=0;i<26;i++) pp[i]=0; for(;*tt;tt++) if(*tt<='z' && *tt>='a') pp[*tt-97]++; } main( )

{ 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 #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 #include #define LEN 20

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 #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 float fun(int n) { int i,sum=1; float s=1; for(i=2;i<=n;i++) { sum=sum+i; s=s+1.0/sum;} return s;} long chsdc(int n) { int i,s; s=0;

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 #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 #include #include float fun() { float x0,x1=0; do { x0=x1;

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 #include #include #define N 5 int fun(int a[][N]) { int i,j; for(i=0;i

-5-


全国计算机二级C上机 编程题.doc 将本文的Word文档下载到电脑 下载失败或者文档不完整,请联系客服人员解决!

下一篇:社会资本与永续社区发展 概念探讨与研究议题

相关阅读
本类排行
× 注册会员免费下载(下载后可以自由复制和排版)

马上注册会员

注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
微信: QQ: