全国计算机二级C上机试题2Word文档下载推荐.docx
《全国计算机二级C上机试题2Word文档下载推荐.docx》由会员分享,可在线阅读,更多相关《全国计算机二级C上机试题2Word文档下载推荐.docx(35页珍藏版)》请在冰豆网上搜索。
函数fun中给出的函数仅供参考。
voidfun(char*a)
{char*p,*q;
intn=0;
p=a;
while(*p==’*’)
{n++;
p++;
}
q=a;
while(*p){
*q=*p;
q++;
for(;
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;
j<
=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)
inti;
doublesum=0.0;
for(i=1;
n;
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;
j++)
第二处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];
第二十七套
函数fun的功能是计算f(x)=1+x-2/2!
+3/3!
-4/4!
+……的前n项和。
若x=2.5,n=15时,函数值为1.917914。
第一处f=1;
第二处t*=(-1)*x/i;
第三处f+=t;
从三个红球,5个白球,6个黑球中任意取出8个作为一组,进行输出。
在没组中,可以没有黑球,但必须要有红球和白球。
组合数作为函数值返回。
正确的组合数应该是15.程序中i的值代表红球数,j代表白球数,k代表黑球数。
=3;
if(k>
=0&
&
k<
=6)
计算并输出下列多项式的值:
sn=1+1/1!
+1/2!
+1/3!
+1/4!
+……1/n!
。
例如:
在主函数中从键盘给n输入15,则输出为:
s=2.718282。
注意:
要求n的值大于1但不大于100。
doubles=1’
longt=1;
i++){
t=t*i;
s+=1.0/t;
returns;
第二十八套
给定程序中,函数fun的功能是:
计算N*N矩阵的主对角线元素和方向对角线元素之和,并作为函数值返回。
要求先累加主对角线元素中的值,然后累加反响对角线元素的值。
第一处sum=0;
第二处sum+=t[i][i];
第三处sum+=t[i][n-i-1];
给定程序MODI1.C中函数fun和funx的功能是:
用二分法求方程2x3-4x2+3x-6=0的一个根,并要求绝对误差不超过0.001。
doubler;
while(fabs(n-m)>
0.001)
除了字符串前导和尾部的*号之外,将串中其他*号全部删除。
形参h已指向字符串中的第一个字母,形参p已指向字符串中最后一个字母。
在编写函数时,不得使用c语言提供的字符串函数。
voidfun(char*a,char*h,char*p)
intj=0;
char*q=a;
while(*q&
q<
h)a[j++]=*q++;
while(*h&
*p&
h<
p)
if(*h!
=’*’)a[j++]=*h;
h++;
while(*p)a[j++]=*p++;
a[j]=0;
第二十九套
有N*N矩阵,将矩阵的外围元素顺时针旋转。
操作的顺序是:
首先将第一行元素的值存入临时数组r,然后使第一列成为第一行,最后一行成为第一列,最后一列成为第一行,临时数组中和元素成为最后一列。
第一处t[0][N-j-1]=t[j][0];
第二处for(j=N-1;
j>
=0;
j--)
第三处t[j][N-1]=r[j];
计算s=f(-n)+f(-n+1)+……+f(0)+f
(1)+f
(2)+……f(n)的值。
例如,当n为5时,函数值应该是:
10.407143。
doublef(doublex)
编写一个函数fun,它的功能是计算:
s=根号下(ln
(1)+ln
(2)+ln(3)+……ln(m))S作为函数返回,在C语言中可以调用log(n)求ln(n)。
log函数引用说明是:
Doublelog(doublex)例如,若m的值为:
20,fun函数值为:
60506583。
doublefun(intm)
doubles=0.0;
for(i=0;
=m;
s+=log(1.0*i);
s=sqrt(s);
第三十套
反形参a所指数组中的奇数按原顺序依次存放到a[0]、a[1]、a
[2]……中,把偶数从数组中删除,奇数个数通过函数值返回。
若a所指数组中的数据最初排列为:
9、1、4、2、3、6、5、8、7,删除偶数后a所指数组中的数据为:
9、1、3、5、7,返回值为5。
第一处if(a[i]%2==1)
第二处j++;
第三处returnj;
求出两个非零正整数的最大公约数,并作为函数值返回。
t=a;
a=b;
b=t;
return(b);
删除字符串中所有的*号。
在编写函数时,不得使用C语言提供的字符串函数。
char*p=a;
if(*p!
=’*’)
a[j++]=*p;
第三十一套
在形参ss所指字符串数组中,删除所有串长超过k的字符串,函数返回所剩字符串的个数。
Ss所指字符串数组中共有N个字符串,且串长小于M。
第一处for(i=0;
N;
第二处if(len<
=k)
第三处strcpy(ss[j++],ss[i]);
逐个比较p、q所指两个字符串对应位置中的字符,把ASCII值或相等的字符依次存放在c所指数组中,形成一个新的字符串。
intk=0;
while(*p||*q)
除了字符串前导*号之外,将串中其它*号全部删除。
函数fun中给出的语句仅供参考。
inti=0,k;
while(a[i]!
==’*’)i++;
=’\0’)
if(a[i]!
a[k++]=a[i];
i++;
a[k]=’\0’;
第三十二套
给定程序中已建立一个带头结点的单向链表,链表中的各结点按结点数据域中的数据递增有序链接。
函数fun的功能是:
把形参x的值放入一个新结点并插入到链表中,插入后各结点数据域的值仍保持递增有序。
第一处s->
data=x;
第二处q=p;
第三处q->
next=s;
计算正整数num的各位上的数字之积。
longk=1;
num/=10
计算n门课程的平均分,计算结果作为函数返回。
floatfun(float*a,intn)
floatave=0.0;
ave=ave+a[i];
ave=ave/n;
returnave;
第三十三套
在形参ss所指字符串数组中,查找含有形参substr所指子串的所有字符串并输出,若没找到输出相应信息。
Ss所指字符串数组中共有N个字符,且串长小于M。
程序中库函数strstr(s1、s2)的功能是早s1串中查找s2子串,若没有,函数值为0,若有,为非0。
第二处if(strstr(ss[i],substr)!
=NULL)
第三处if(find==0)
求三个数的最小公倍数。
fun(intx,inty,intz)
returnj;
只删除字符串前导和尾部的*号,串中字母之间的*号都不删除。
形参n给出了字符串的长度,形参h给出了字符串中前导*号的个数。
voidfun(char*a,intn,inth,inte)
intj=0,len=0;
while(*p){p++;
len++;
while(j<
len-h-e){
a[j]=a[h+j];
j++;
第三十四套
在形参ss所指字符串数组中查找与形参t所指字符串相同的串,找到后返回该串在字符串中的位置(下标值),未找到则返回-1。
ss所指字符串数组中共有N个内容不同的字符串,且串长小于M。
第二处
if(strcmpss[i],t)==0
returni;
第三处if(n==-1)
printf(“\nDon’tfound!
\n”);
从整数1到55之间,选出能被3整除、且有一位上的数是5的那些事,并且把这些数放在b所指的数组中,这些数作为函数值返回。
规定,函数中a1放个位数,a2放十位数。
a2=k/10;
returni;
将字符串尾部的*号全部删除,前面和中间的*号不删除。
while(*p)p++;
p--;
while(*p==’*’)p--;
*p=0;
第三十五套
统计出带有头结点的单向链表中结点的个数,存放在形参n所指的存储单元中。
第一处*n=0;
第二处p=p->
next;
第三处fun(head,&
num);
求出s所指字符串最后一次出现的t所指字符串的地址,通过函数值返回,在主函数中输出从此地址开始的字符串;
若未找到,则函数值NULL。
a=NULL;
if(*r==*p)
将s所指字符串中除了下标为偶数,同时ASCII指也为偶数的字符外,其余的全部都删除:
串中剩余字符所形成的一个新串放在t所指的数组中。
voidfun(char*s,chart[])
inti,j=0;
strlen(s);
i+=2)
if(s[i]%2==0)t[j++]=s[i];
t[j]=0;
第三十六套
进行数字字符转换。
若形参ch中是数字字符‘0’—‘9’,则‘0’转换成‘9’,‘1’转换成‘8’,‘2’转换成‘7’,……‘9’转换成‘0’;
若是其他字符则保持不变,并将转换后的结果做函数值返回。
第一处charfun(charch)
第二处if(ch>
=’0’&
ch<
=’9’)
第三处return‘9’-(ch-‘0’);
将p所指字符串中所有字符复制到b中,要求复制第三个字符之后插入一个空格。
b[k]=*p;
b[k++]=’‘;
N名学生的成绩已在主函数中放入一个带头结点的链表结构中,h指向链表的头结点。
求出平均分,有函数值返回。
doublefun(STREC*h)
STREC*p=h->
next;
doubleav=0.0;
intn=o;
while(p!
av=av+p->
s;
p=p->
n++;
av/=n;
returnav;
第三十七套
把形参a所指数组中的偶数按原顺序依次存放a[0]、a[1]、a[2]……中,把奇数从数组中删除,偶数个数通过函数值返回。
第一处if(a[i]%2==0){
第二处a[j]=a[i];
按以下递推公式求函数值。
例如,当给n输出5时,函数值为18;
当给n输入3时,函数值为14.
fun(intn)
if(n==1)
使字符串中尾部的*号不得多于n个;
若多于n个则删除多余的*号;
若少于或等于n个,则什么也不做,字符串中间和前面的*号不删除。
voidfun(char*a,intn)
n&
*p){
第三十八套
利用指针数组对形参ss所指字符串数组中的字符串按由长到短的顺序排列,并输入排序结果。
ss所指定字符串数组中共有N个字符串,且串长小于M。
第一处k=i
第二
if(strlen(ps[k])<
strlen(
ps[j]))k=j;
第三处tp=ps[i];
ps[i]=ps[k];
ps[k]=tp;
已知一个数列从第0项开始的前三项分别是0、0、1以后的各项都是它相邻的前三项之和。
给定程序MODI1.C中函数fun的功能是:
计算并输出该数列前n项的平方根之和。
n的值通过形参传入。
计算下列级数和,和值由函数值返回。
例如,当n=10,x=0.3时,函数值为1.349859。
doublefun(doublex,intn)
{doubles=1.0,y=x;
s+=y/(double)jc(i);
y*=x;
第三十九套
计算x所指数组中N个数的平均值(规定所有数均为正数),平均值通过形参返回主函数,将小于平均值且最接近平均值的数作为函数值返回,在主函数中输出。
第一处*av=s/N;
第二处d=*av-x[i];
j=i;
第三处returnx[j];
根据整型形参n计算如下公式的值。
若n=10,则应输出:
0.617977.
floatfun(intn)
for(i=2;
程序定义了N×
N的二维数组,并在主函数中自动赋值,请编写函数fun,它的功能是:
使数组右上三角元素中的值乘以m。
intfun(inta[][N],intm)
inti,j;
for(j=i;
a[i][j]*=m;
第四十套
将s所指字符串所有数字字符移到所有非数字字符之后,并保持数字字符串和非数字字符串原有的先后次序。
第一处j++;
第二处s[i]=t1[i];
第三处for(i=0;
j;
用冒泡法对6个字符串按由小到大的顺序排列。
for(j=i+1;
6;
*(pstr+i)=*(pstr+j);
求出ss所指字符串中指定字符个数,并返回次值。
intfun(char*ss,charc)
intcnt=0;
char*p=ss;
if(*p==c)cnt++;
returncnt;
第四十一套
将形参s所指定字符串中的数字字符转换成对应的数值,计算出这些数值的累加和作为函数值返回。
第1处
if(isdigit(*s))sum+=*s-48;
第2处s++;
第3处returnsum;
计算小于形参k的最大的10个能被13或17整除的自然数之和。
K的值由主函数传入,若K的值为500.则主函数为4622。
if((k%13==0││(k%17==0))
求小于形参n同时能被3和7整除的所有自然数之和的平方根,并作函数的返回值。
do