全国计算机等级考试二级C语言上机模拟训练题库共50套文档格式.docx
《全国计算机等级考试二级C语言上机模拟训练题库共50套文档格式.docx》由会员分享,可在线阅读,更多相关《全国计算机等级考试二级C语言上机模拟训练题库共50套文档格式.docx(46页珍藏版)》请在冰豆网上搜索。
0.536389。
for(i=2;
=m;
i++)
y-=1.0/(i*i);
m个人的成绩存放在score数组中,请编写函数fun,它的功能是:
将低于平均分的人数作为函数值返回,将低于平均分的分数放在below所指的数组中。
intfun(intscore[],intm,intbelow[])
floatav=0.0;
for(i=0;
m;
av+=score[i];
av/=m;
if(av>
score[i])
below[j++]=score[i];
returnj;
第三套
给定程序中,函数fun的功能是将形参指针所指结构体数组中的三个元素按num成员进行升序排列。
第1处voidfun(PERSON*std)
第2处PERSONtemp;
第3处fun(std);
将m(1≦m≦10)个字符串连接起来,组成一个新串,放入pt所指存储区中。
intk,q,i;
pt[i]=str[k][i];
程序定义了N×
N的二维数组,并在主函数中自动赋值。
请编写函数fun(inta[][N]),函数的功能是:
使数组左下三角元素中的值全部置成0。
intfun(inta[][N])
inti,j;
N;
for(j=0;
j<
=i;
j++)
a[i][j]=0;
第四套
计算形参x所指数组中N个数的平均值(规定所有数均为正数),作为函数值返回,并将大于平均值的数放在形参Y所指数组中,在主函数中输出。
第1处av=0;
第2处av=av+x[i]/N;
第3处y[j++]=x[i];
根据整形形参m,计算如下公式的值。
doublefun(intm)
for(i=100;
i+=100)
已知学生的记录由学号和学习成绩构成,N名学生的数据已存入a结构体数组中,轻便鞋函数的功能是:
找出成绩最低的学生记录,通过形参返回主函数(规定只有一个最低分)
fun(STUa[],STU*s)
inti,min=a[0],s,j=0;
if(min>
a[i].s){
j=i;
min=a[i].s;
*s=a[j];
第五套
1程序填空
判断形参s所指字符串是否是“回去”(Palindrome)若是,函数返回值为1;
不是,函数返回值为0,“回文”是正读和反读都是一样的字母串(不区分大小写字母)。
第1处1p=s;
第2处1p++;
rp--;
第3处if(1p<
rp)return0;
求出以下分数序列的前n项之和。
2/1+3/2+5/3+8/5+13/8+21/13+……和值通过函数值返回main函数。
例如n=5,则应输出:
8.391667。
doublefun(intn)
c=a;
a+=b;
b=c;
3程序设计
请编写函数fun,函数的功能是:
将大于形参m且紧靠m的k个素数存入xx所指的数组中。
19,23,29,31,37,函数fun中给出的语句仅供参考。
voidfun(intm,intk,intxx[])
inti,j=1,t=m+1;
while(j<
=k)
t;
if(t%i==0)break;
if(i==t){
xx[j-1]=i;
j++;
t++;
第六套
给定程序的功能是:
从键盘输入若干行文本(每行不得超过80个字符),写到文件myfile4.txt中,用-1作为字符串输入结束的标志。
然后将文件的内容读出显示在屏幕上。
文件的读写分别由自定义函数ReadText和WriteText实现。
第1处voidWriteText(FILE*fw)
第2处fputs(str,fw);
fputs(“\n”,fw);
第3处printf(“%s”,str);
从低位开始取出长整形变量s中奇数位上的数,依次构成一个新数t中。
高位仍在高位,低位仍在低位。
voidfun(longs,long*t)
s1=s1*10;
将两个两位数的正整数a、b合并形成一个整数放在c中。
合并的方式是:
将a数的十位和个位数依次放在c数的十位和百位上,b数的十位和个位数依次放在c数的千位和十位上。
voidfun(inta,intb,long*c)
*c=(b/10)*1000+(a%10)*100+(b%10)*10+(a/10);
第七套
计算出形参s所指字符串中包含的单词个数,作为函数值返回。
为便于统计,规定各单词之间用空格隔开。
第1处n++;
flag=1;
第2处if(*s==’’)flag=0;
第3处s++;
从n(形参)个学生的成绩中统计出低于平均分的学生人数,此人数由函数值返回,平均分存放在形参aver所指的存储单元中。
t+=s[k];
*aver=ave;
请编写函数fun,其功能是求出数组的最大元素在数组中的下标并存放在k所指的存储单元。
intfun(int*s,intt,int*k)
inti,pos=0,max=*s;
if(max<
*(s+i)){
max=*(s+i);
pos=i;
}}
*k=pos;
第八套
给定程序中,函数fun的功能是计算下式s=3/22-5/42+7/62-…+(-1)n-1(2×
n2)︱≤10-3并把计算结果作为函数值返回,例如:
若形参e的值为-le-3,函数的返回值为0.551690。
第1处x=3.0/4;
第2处while(x>
e)
第3处x=(2*i+1)/(t*t);
2/1,3/2,5/2,8/5,13/8,31/13…和值通过函数值返回到main函数。
doublefun(intn)
s=s+(double)a/b;
请编写函数fun,它的功能是:
求出一个2×
M整型二维数组中最大元素的值,并将此值返回调有函数。
fun(inta[][M])
inti,j,max=a[0][0];
2;
M;
a[i][j])
max=a[i][j];
returnmax;
第九套
把形参a所指数组中的的最小值放在元素a[0],接着把形参a所指数组中的最大值放a[1]元素中;
再把a所指数组中的次小值放在a[2]中,把a所指数组元素中的次大值放在a[3];
其余以此类推。
第1处max=min=a[i];
第2处if(max<
a[j])
第3处if(min>
用递归算法计算列中第n项的值。
从第一项起,斐波拉契数列为:
1、1、2、3、5、8、13、21、……
switch(g)
case1:
return1;
case2:
某学生的记录由学号、8门课程和平均分组成,学号和8门课程成绩已在主函数中给出。
请编写函数fun,它的功能是;
求出该学生的平均分放在记录的ave成员中。
voidfun(STREC*a)
{inti;
a->
ave=a->
ave+a->
s[i];
a->
ave/=N
第十套
有N×
N矩阵,以主对角线为对称线,对称元素相加并将结果存放在左下三角元素中,右上三角元素来。
第1处voidfun(int)(*t)[N]
第2处t[i][j]=t[i][j]+t[j][i];
第3处t[j][i]=0;
2程序修改
计算函数值,F(x,y,z)=(x+y)/(x-y)+(z+y)/(z-y)其中x和y的值不等,z和y的值不等。
例如,当x的值为9、y的值为11、z的值为15时,函数值为-3.50。
/**found**/
#defineFU(m,n)((m)/(n))
return(value);
}
规定输入的字符串中只包含字母和*号。
请编写函数fun,它的功能是:
将字符串中的前导*号全部删除,中间和尾部的*号不删除。
voidfun(char*a)
{
intj=0;
char*p=a;
while(*p=='
*'
)p++;
while(*p){
a[j++]=*p;
p++;
a[j]=0;
第十一套
1.程序填空
给定程序中,函数fun的功能是:
计算形参x所指数组中N个数的平均值,(规定所有数均为正数),将所指数组中大于平均值的数据移至数据的前部,小于等于平均数的移至x所指数组的后部,平均值作为函数值返回,在主函数中输出平均值和移动后的数据。
第一处av=s/N;
第二处y[j++]=x[i];
x[i]=-1;
第三处if(x[i]!
=-1)
y[j++]=x[i];
2.程序修改
给定程序MODI1.C中函数fun的功能是:
读入一行英文文本行,将其中每个单词的第一个字母改成大写,然后输出次文本行(这里的“单词”是指由空格隔开的字符串)。
#include<
stdio.h>
upfst(char*p)
3.程序设计
程序定义了N×
N的二级数组,并在主函数中赋值,请编写函数fun,函数的功能是:
求出数组周边元素的平均值并作出函数值饭给主函数中的s。
doublefun(intw[][N])
{inti,j,n=0;
doublesum=0;
{sum+=w[0][i]+w[N-1][i];
n+=2;
N-1;
{sum+=w[i][0]+w[i][N-1];
returnsum/n;
第十二套
将自然数1—10以及它们的平方根写到名为myfile3.txt的文本文件中,然后再顺序读出显示在屏幕上。
第一处fprintf(fp,”%d%f\n”,i,sqrt((double)i));
第二处fclose(fp);
第三处if((fp=fopen(fname,”r”))==NULL)
将n个无序整数从小到大排序。
for(i=j+1;
n;
p=i;
函数fun的功能是:
将a、b中的两位正整数合并形成一个新的整数放在c中。
将a中的十位和个位依次放在变量c的个位和百位上,b中的十位和个位数依次放在变量c的十位和千位上。
#include<
voidfun(inta,intb,long*c)
*c=(b%10)*1000+(a%10)*100+(b/10)*10+(a/10);
第十三套
找出N*N矩阵中每列元素中的最大值,并按顺序一次存放于形参b所指的一维数组中。
第一处b[i]=a[0][i];
第二处if(b[i]<
a[j][i])
b[i]=a[j][i];
第三处fun(x,y);
交换主函数中的两个变量的值。
intfun(int*x,int*y)
t=*x;
*x=*y;
*y=t;
编写函数fun,函数的功能是求出小于或等于lim的所有素数并放在aa数组中,函数返回所求出的素数的个数。
函数fun中给出的语句仅供参考。
#defineMAX100
intfun(intlim,intaa[MAX])
{inti,j,k=0;
=lim;
for(j=2;
=(i/2);
if(i%j==0)break;
if(j>
(i/2))aa[k++]=i;
}returnk;
第十四套
函数fun的功能是进行字母转换。
若形参ch中小写英文字母,则转换成相应的大写英文字母;
若形参ch中是大写英文字母,则转换成相应的小写英文字母;
并将转换的结果作为函数值返回。
第一处if((ch>
=’a’)&
&
(ch<
=’z’))
第二处return
ch+’a’-‘A’
第三处returnch;
给一维数组a输入任意四个整数并按下列的规律输出。
例如输出1、2、3、4,程序输出一下方阵。
a)123
3412
2341
1234
voidfun(int*a)
a[j]=a[j-1];
请编写函数fun,函数的功能是:
计算并输出给定整数n的所有因子(不包过1和n本身)之和。
规定n的值不大于1000.
intfun(intn)
ints=0,i;
if(n%i==0)s+=i;
returns;
第十五套
给定程序中,函数的功能是:
把形参s所指字符串下标为奇数的字符右移到下一个奇书位置,最右边呗移出字符串的字符绕回放到第一个奇数位置,下标为偶数的字符不动(注:
字符串的长度大于等于2)。
例如,形参s所指的字符串为:
abcdefgh,执行结果为:
ahcbedg。
第一处if(n%2==0)k=n-1;
第二处c=s[k];
第三处s[1]=c;
求s=aa…aa—…—aaa—aa—a(此处aa…aa表示n个a,a和n的值在1至9之间)。
longs=0,t=0;
t=t/10;
请编写一个函数voidfun(char*tt,intpp[]),统计在tt所指字符串中‘a’至‘z’26个小写字母各自出现在的次数,并依次放在pp数组中。
voidfun(char*tt,intpp[])
char*p=tt;
inti;
26;
pp[i]=0;
while(*p)
{if(*p>
=’a’&
*p<
=’z’)
pp[*p-‘a’]+=1;
p++;
第十六套
人员的记录由编号和出生年、月、日组成,N名人员的数据已在主函数中存入结构体数组std中,且编号唯一。
找出指定编号人员数据,作为函数值返回,由主函数输出,若指定编号不存在,返回数据中编号为空串。
第1处STUfun(STU*std,char*num)
第2处if(strcmp(std[i].num,num)
==0)
第3处return(std[i]);
从s所指字符串中,找出与t所指字符串相同的子串的个数作为函数值返回。
r++;
if(*r==0)
将s所指字符串中ASCII值为偶数的字符删除,串中剩余字符形成一个新串放在t所指数组中。
stdio.h>
string.h>
voidfun(char*s,chart[])
inti,j=0;
if(s[i]%2)t[j++]=s[i];
第十七套
统计形参s所指字符串中数字字符出现的次数,并存放在形参t所指的变量中,最后在主函数中输出。
abcdef35adgh3kjsdf7。
输出结果为:
4。
第1处for(i=0;
s[i]!
=NULL;
第2处if(s[i]>
=’0’&
s[i]<
=’9’)
n++;
第3处*t=n;
通过某种方式实现两个变量的交换,规定不允许增加语句和表达式。
例如变量a中的值原为8,b中的值原为3,程序运行后a中值为3,b中的值为8.
*x=y;
return(t);
求出1到1000之间能被7或11整除,但不能同时被7和11整除的所有整数并将它们放在a所指的数组中,通过n返回这些数的个数。
viodfun(int*a,int*n)
{inti;
*n=0;
for(i=7;
1000;
if(((i%7)==0││(i%11)==0
(i%77)!
=0)a[(*n)++]=i;
第十八套
N矩阵,根据给定的m(m<
=n)值,将每行元素中的值均右移m个位置,左边值为0.
第2处t[i][j+m]=t[i][j];
第3处for(j=0;
计算并输出high以内最大的10个素数之和。
high的值由主函数传给fun函数。
while((2<
=high)&
(n<
10))
yes=0;
break;
利用一下所示的简单迭代方法求方程求方程:
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.739058。
floatfun()
floatx0,x1=0.0;
do{
x0=x1;
x1=cos(x0);
}while(fabs(x0-x1)>
0.000001);
returnx1;
第十九套
将a所指的3×
5矩阵中第k列的元素左移到第0列,第k列以后的每列元素行依次左移,原来左边的各列依次绕到右边。
第1处for(p=1;
p<
=k;
p++)
第2处for(j=0;
a[i][j]=a[i][j+1];
第3处a[i][N-1]=temp;
根据形参m的值(2<
=m<
=9),在m行m列的二维数组中存放如下所示规律的数据,由main函数输出。
例如,若输入2则输出:
12
24
fun(inta[][M],intm)
a[j][k]=(k+1)*(j+1);
将a中的十位和个位依次放在变量c的十位和千位上,b中的十位和个位数依