C语言二级考试机试题库docWord文档下载推荐.docx
- 文档编号:5799179
- 上传时间:2023-05-05
- 格式:DOCX
- 页数:46
- 大小:31.25KB
C语言二级考试机试题库docWord文档下载推荐.docx
《C语言二级考试机试题库docWord文档下载推荐.docx》由会员分享,可在线阅读,更多相关《C语言二级考试机试题库docWord文档下载推荐.docx(46页珍藏版)》请在冰点文库上搜索。
第一处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;
for(i=0;
26;
pp[i]=0;
while(*p)
{if(*p>
=’a’&
*p<
=’z’)
pp[*p-‘a’]+=1;
p++;
第十六套
人员的记录由编号和出生年、月、日组成,N名人员的数据已在主函数中存入结构体数组std中,且编号唯一。
函数fun的功能是:
找出指定编号人员数据,作为函数值返回,由主函数输出,若指定编号不存在,返回数据中编号为空串。
第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)
函数fun的功能是:
将s所指字符串中ASCII值为偶数的字符删除,串中剩余字符形成一个新串放在t所指数组中。
#include<
stdio.h>
string.h>
voidfun(char*s,chart[])
inti,j=0;
strlen(s);
if(s[i]%2)t[j++]=s[i];
t[j]=0;
第十七套
给定程序中,函数fun的功能是:
统计形参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.
t=*x;
*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×
N矩阵,根据给定的m(m<
=n)值,将每行元素中的值均右移m个位置,左边值为0.
N;
第2处t[i][j+m]=t[i][j];
第3处for(j=0;
j<
m;
j++)
计算并输出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;
N-1;
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、b中的两位正整数合并形成一个新的整数放在c中。
合并的方式是:
将a中的十位和个位依次放在变量c的十位和千位上,b中的十位和个位数依次放在变量c的个位和百位上。
voidfun(inta,intb,int*c)
*c=(a%10)*1000+(b%10)*100
+(a/10)*10+(b/10);
第二十套
对形参s所指字符串中下标为奇数的字符ASCII码大小递增排序,并将排序后的下标为奇数的字符取出,形成一个新串。
第1处t=i;
第2处for(j=i+2;
j=j+2)
第3处p[j]=0;
用下面的公式求π的近似值,知道最后一项的近似值小于指定数(参数num)为止:
例如程序0.0001,则程序输出3.1414。
while((fabs(t))>
=num)
t=s/n
请编写一个函数voidfun(chara[],charb[],intn),其功能是:
删除一个字符串指定下标的字符。
其中,a指向原字符串,删除指定字符后的字符串放在b所指的n中存入指定的下标。
viodfun(chara[],char
b[],intn)
strncpy(b,a,n);
b[n]=0;
strcat(b,a+n+1);
第二十一套
在形参ss所指字符串数组中,将所有串长超过k的字符串右边的字符删去,只保留左边的k个字符。
ss所指字符串数组中共有N个字符串,且串小于M。
第一处voidfun(char(*ss)[M],intk)
第二处while(i<
N){
第三处ss[i][k]=0;
i++;
根据以下公式求π值,并作为函数值返回。
例如,给指定精度的变量eps输入0.0005时,应当输出Pi=30140578.。
t=1;
return(2*s);
假定输入字符串中只包含字母和*号。
请编写函数fun,它的功能是:
将字符串的前导*号不得多于n个;
若多于n个,则删除多余的*号;
若少于或等于n个,则什么也不做,字符串中间和尾部的*号不删除。
函数fun中给出的语句仅供参考。
voidfun(char*a,intn)
inti=0,k=0;
while(a[k]==’*’)k++;
if(k>
n)
i=n;
j=k;
for(;
a[j]!
=0;
a[i++]=a[j];
a[i]=0;
}}
第二十二套
a所指4×
3矩阵中第k行的元素与第0行元素交换。
例如:
有下列矩阵
123
456
789
101112
若k为2,程序执行结果为
第一处voidfun(int(*a)[N],intk)
第二处for(i=0;
第三处a[0][i]=a[k][i];
读入一个字符串(长度<
20),将该字符串中的所有字符串按ASCII码升序排序后输出。
例如,若输入edcba,则应输出:
abcde。
for(i=strlen(t)-1;
i;
i--)
if(t[j]>
t[j+1])
将ss所指字符串中所有下标为奇数位置上的字母转换为大写(若该位置上不是字母,则不转换)。
voidfun(char*ss)
char*p=ss;
inri=0;
while(*p){
if((i%2)&
(*p>
=’a’&
*p-=32;
第二十三套
给定程序的功能是:
调用函数fun将指定源文件中的内容复制到指定的目标文件中,复制成功时函数的返回值是1,失败是返回值是0.在复制的过程中,把复制的内容输出到终端屏幕。
主函数源文件名放在变量sfname中,目标文件放在变量tfname中。
第一处
if((fs=fopen(source,”r”))==NULL)
第二处while(!
feof(fs))
第三处fputc(ch,ft);
将长整型中每一位上为偶数的数依次取出,构成一个新数放在t中。
高位仍在高位,低位仍在低位。
if(d%2==0)
s/=10;
将两位正整数a、b合并形成一个新的整数放在c中。
将a中的十位和个位依次放在变量c的十位和千位上,b中的十位和个位数依次放在变量c的百位和个位上。
voidfun(inta,intb,long*c)
*c=(a%10)*1000+(b/10)*100+(a/10)*10+(b%10);
第二十四套
程序通过定义学生结构体变量,存储了学生的学号、姓名和三门课的成绩。
函数fun的功能是将形参a所指结构体变量中的数据赋给函数中的结构体变量b,并修改b中的学号和姓名,最后输出修改后的数据。
第一处b=a;
第二处strcpy(b.name,”LiSi”)
第三处for(i=0;
3;
printf(“%6.2f”,b.score[i]);
从s所指字符串中删除所有小写字母c。
请改正程序中的错误,使它能计算出正确的结果。
s[j++]=s[i];
s[j]=’\0’;
假定输入的字符串中只包含字母和*号。
将字符串的前导*号全部移到字符串的尾部。
函数fun中给出的函数仅供参考。
voidfun(char*a)
{char*p,*q;
intn=0;
p=a;
while(*p==’*’)
{n++;
q=a;
*q=*p;
q++;
n>
0;
n--)
*q++=’*’;
*q=’\0’;
第二十五套
用筛选法可得到2—n(n<
10000)之间的所有素数,方法是:
首先从素数2开始,将所有2的倍数的数从数表中删去(把数表中相应位置的值置成0);
接着从数表中找下一个非0数,并从数表中删去该数的所有倍数,依此类推,直到所找的下一个数等于n为止。
这样会得到一个序列:
2、3、5、7、11、13、17、19、23……函数fun用筛选法找出所有小于等于n的素数,并统计素数的个数作为函数值返回。
第一处for(j=a[i]*2;
=n;
j+=a[i])
第二处while(a[i]==0)
第三处if(a[i]!
=0)
为一个偶数寻找两个素数,这两个素数之和等于该偶数,并将这两个素数通过形参指针传回主函数。
y=1;
/**foune**/
d=a-i;
请编写函数fun,它的功能是:
计算并输出n(包括n)以内能被5或9整除的所有自然数的倒数之和。
doublefun(intn)
doublesum=0.0;
for(i=1;
if(i%5==0||i%9==0)
sum+=1.0/i;
returnsum;
第二十六套
给定程序中,函数fun的功能是建立一个N×
N的矩阵。
矩阵元素的构成规律是:
最外层元素的值全部是1;
从外向内第二层元素的值全部为2;
第三层元素的值全部是3,…依此类推。
第一处voidfun(int(*a)[N])
第二处for(j=i;
N-i;
第二处a[k][i]=a[k][N-i-1]=i+1;
将十进制正整数m转换成k(2<
=k
<
=9)进制数,并按高位到低位顺序输出。
aa[i]=m%k;
printf(“%d”,aa[i-1]);
编写一个函数,从num个字符串中找出最长的一个字符串,并通过形参指针max传回该串地址。
(注意:
主函数中用****作为结束输入的标志,函数fun中给出的语句仅供参考)。
fun(char(*a)[81],intnum,char**max)
inti,k=0,maxlen;
maxlen=strlen(a[k]);
num;
if(strlen(a[i])>
maxlen)
{maxlen=strlen(a[i]);
k=i;
*max=a[k];
第五十三套
1程序填空
给定程序中,函数fun的功能是将形参指针所指结构体数组中的三个元素按num成员进行升序排列。
第1处voidfun(PERSON*std)
第2处PERSONtemp;
第3处fun(std);
2程序修改
给定程序MODI1.C中函数fun的功能是:
将m(1≦m≦10)个字符串连接起来,组成一个新串,放入pt所指存储区中。
intk,q,i;
pt[i]=str[k][i];
3程序设计
程序定义了N×
N的二维数组,并在主函数中自动赋值。
请编写函数fun(inta[][N]),函数的功能是:
使数组左下三角元素中的值全部置成0。
intfun(inta[][N])
inti,j;
for(j=0;
=i;
a[i][j]=0;
第五十四套
给定程序中,函数fun的功能是:
计算形参x所指数组中N个数的平均值(规定所有数均为正数),作为函数值返回,并将大于平均值的数放在形参Y所指数组中,在主函数中输出。
第1处av=0;
第2处av=av+x[i]/N;
第3处y[j++]=x[i];
根据整形形参m,计算如下公式的值。
doublefun(intm)
for(i=100;
=m;
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。
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数的千位和十位上。
*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×
n-1)/(2×
n)2直到︱(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函数。
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 语言 二级 试机 试题库 doc