全国计算机等级考试二级C语言上机题库Word格式文档下载.docx
《全国计算机等级考试二级C语言上机题库Word格式文档下载.docx》由会员分享,可在线阅读,更多相关《全国计算机等级考试二级C语言上机题库Word格式文档下载.docx(91页珍藏版)》请在冰豆网上搜索。
第二处q=p->
next;
第三处q=q->
2.程序修改
用选择法对数组中的n各元素按从小到大的顺序进行排序。
p=j;
p=i;
3.程序设计
请编写一个fun函数,它的功能是:
求出1到m之间(含m)能被7或11整除的所有整数放在数组a中,通过n返回这些数的个数。
voidfun(intm,int*a,int*n)
{
inti;
*n=0;
for(i=7;
=m;
if((i%7==0)||(i%11==0))
a[(*n)++]=i;
}
第三套
逆置数组元素是的值。
例如:
若a所指数组中的数据依次为:
1、2、3、4、5、6、7、8、9,则逆置后依次为:
9、8、7、6、5、4、3、2、1。
形参n给出数组中数组中数据的个数。
第一处for(i=0;
n/2;
第二处a[i]=a[n-1-i];
第三处a[n-i-1]=t;
2程序修改
将一个由八进制数字字符串组成的字符串转换为与其面值相等的十进制整数。
规定输入的字符串最多只能包含5位八进制数字字符。
n=*p-‘0’;
n=n*8+*p-‘0’;
函数返回指定学号的学生数据,指定的学生号在主函数中输入,若没有找到指定学号,在结构体变量中给学号置空串,给成绩置-1,作为函数值返回。
(用于字符串比较的函数是strcmp)。
STRECfun(STREC*a,char*b)
STRECc;
Inti;
c.num[0]=’\0’;
c.s=-1;
if(strcmp(a[i].num,b)==0)
{strcpy(c.num,a[i].num);
c.s=a[i].s;
break;
returnc;
第四套
给定程序中,函数fun的功能是:
在带有头结点的单向链表中,查找数据域中值为ch的结点。
找到后通过函数值返回该结点在链表中所处的顺序号:
若不存在值为ch的结点,函数值返回0.
第一处while(p!
=0)
第二处if(p->
data==ch)returnn;
第三处k=fun(head,ch);
删除p所指字符串的所有空白字符(包括制表符、回车符及换行符)。
输入字符串时用‘#’结束输入。
for(i=0,t=0;
p[i];
c[t]=’\0’;
请编写一个函数fun,将ss所指字符串中所有下标为奇数位置上的字母转换为大写(若该位置上不是字母,则不转换)。
voidfun(char*ss)
for(i=1;
strlen(ss);
i+=2)
{if(ss[i]>
=’a’&
ss[i]<
=’z’)
ss[i]-=32;
第五套
计算下式前n项的和作为函数值返回。
当形参n的值为10的时,函数返回:
9.6125588。
第一处s=0;
第二处for(i=1;
=n;
第三处s=s+(2.0*i-1)*(2.0*i+1)/(t*t);
统计substr所指字符串在str所指字符串中出现伯次数。
str[i];
if(substr[k+1]==’\0’)
请编写一个函数fun,它的功能是:
根据以下公式求JI的值(要求满足精度0.0005,即某项小于0.0005时停止送代):
程序运行后,如果输入精度为0.0005,则程序输出为3.14…。
doublefun(doubleeps)
{doubles=1,t=1./3;
intn=1;
while(t>
=eps)
{s+=t;
n++;
t=t*n/(2.0*n+1)
;
return(s*2.0);
第六套
将形参s所指定字符串中所有的字母字符顺序前移,其他字母顺序后移,处理后字符串的首地址作为函数值返回。
第一处t[j]=s[i];
j++;
k;
t[j+i]=p[i];
第三处t[j+k]=0;
将s所指字符串中最后一次出现的与t1所指字符串相同的子串替换成t2所指定字符串,所形成的新串放在w所指的数组中。
在此处,要求t1和t2所指字符串的长度相同。
while(*w)
if(*r==*p)
将s所指字符串中ASCII值为奇数的字符删除,串中剩余字符形成一个新串放在t所指定的数组中。
voidfun(char*s,chart[])
{inti,j=0;
strlen(s);
if(s[i]%2==0)t[j++]=s[i];
t[j]=0;
第七套
程序通过定义学生结构体变量,存储了学生的学号、姓名和三门课的成绩。
函数fun的功能是将形参a所指结构体变量s中的数据进行修改,并把a中地址作为函数值返回主函数,在主函数中输出修改后的数据。
第一处structstudent*
fun(structstudent*a)
3;
a->
score[i]+=1;
第三处returna;
从N个字符串中找出最长的那个串,并将其地址作为函数值返回。
各字符串在主函数中输入,并放在一个字符串数组中。
char*fun(char(*sq)[M])
returnsp;
将a、b中的两位正整数合并形成一个新的整数放在c中。
合并的方式是:
将a中的十位和个位依次放在变量c的百位和个位上,b中的十位和个位数依次放在变量c的十位和千位上。
#include<
stdio.h>
voidfun(inta,intb,long*c)
{*c=(b%10)*1000+(a/10)*100+(b/10)*10+a%10;
第八套
将形参观者工所指数组中的前半部分元素中的值和后半部分元素中的值对换。
形参n中存放数组中数据的个数,若n为奇书,则中间元素不动。
第一处p=(n%2==0)?
n/2:
n/2+1;
第二处a[i]=a[p+i];
第三处a[p+i]=t;
把主函数中输入的三个数,最大的放在a中,最小的放在c中,中间的放在b中。
floatk;
if(*a<
*c)
把分数最高的学生数据放在b所指的数组中,注意:
分数最高的学生可能不止一个,函数返回分数最高的学生的人数。
intfun(STREC*a,STREC*b)
inti,max=a[0].s,n=0;
if(max<
a[i].s)max=a[i].s;
if(max==a[i].s)b[n++]=a[i];
returnn;
第九套
计算形参x所指数组中N个数的平均值,(规定所有数均为正数),将所指数组中小于平均值的数据移至数据的前部,大于等于平均数的移至x所指数组的后部,平均值作为函数值返回,在主函数中输出平均值和移动后的数据。
av+=x[i]/N
第二处y[j]=x[i];
x[i]=-1;
第三处i++;
统计字符串各元音字母(即:
A、E、I、O、U)的个数。
注意字母不分大小写。
num[k]=0;
switch(*s)
请编写函数fun,函数的功能是:
求出二级数组周边元素之和,作为函数值返回。
二维数组中的值在主函数中赋予。
intfun(inta[M][N])
inttot=0,i,j;
tot+=a[0][i];
tot+=a[M-1][i];
M-1;
i++){
tot+=a[i][0];
tot+=a[i][N-1];
returntot;
第十套
函数fun的功能是将形参a中的数据进行修改,把修改后的数据作为函数值返回主函数进行输出。
第一处structstudent
fun(structstudenta)
第二处strcpy(a.name,”LiSi”);
第三处a.score[i]+=1;
假定整数数列中的数不重复,并存放在数组中。
删除数列中值为x的元素。
N中存放的是数列中元素的个数。
if(p==n)return-1’
a[i]=a[i+1];
把分数最低的学生数据放在b所指的数组中,注意:
分数最低的学生可能不止一个,函数返回分数最低的学生的人数。
inti,j=0,min=a[0].s;
{if(min>
a[i].s){
j=0;
min=a[i].s;
elseif(min==a[i].s)
第十一套
计算形参x所指数组中N个数的平均值,(规定所有数均为正数),将所指数组中大于平均值的数据移至数据的前部,小于等于平均数的移至x所指数组的后部,平均值作为函数值返回,在主函数中输出平均值和移动后的数据。
第一处av=s/N;
第二处y[j++]=x[i];
第三处if(x[i]!
=-1)
y[j++]=x[i];
读入一行英文文本行,将其中每个单词的第一个字母改成大写,然后输出次文本行(这里的“单词”是指由空格隔开的字符串)。
#include<
upfst(char*p)
程序定义了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;
将a中的十位和个位依次放在变量c的个位和百位上,b中的十位和个位数依次放在变量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;
for(i=2;
=lim;
for(j=2;
j<
=(i/2);
j++)
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];
计算并输出给定整数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;
26;
pp[i]=0;
while(*p)
{if(*p>
*p<
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++;
p++;
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’)
第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;
1000;
if(((i%7)==0││(i%11)==0
(i%77)!
=0)a[(*n)++]=i;
第十八套
有N×
N矩阵,根据给定的m(m<
=n)值,将每行元素中的值均右移m个位置,左边值为0.
第2处t[i][j+m]=t[i][j];
第3处for(j=0;
m;
计算并输出high以内最大的10个素数之和。
high的值由主函数传给fun函数。
while((2<
=high)&
(n<
10))
yes=0;
利用一下所示的简单迭代方法求方程求方程:
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;
j+