全国计算机二级C上机试题2Word文档下载推荐.docx

上传人:b****6 文档编号:17583551 上传时间:2022-12-07 格式:DOCX 页数:35 大小:28.95KB
下载 相关 举报
全国计算机二级C上机试题2Word文档下载推荐.docx_第1页
第1页 / 共35页
全国计算机二级C上机试题2Word文档下载推荐.docx_第2页
第2页 / 共35页
全国计算机二级C上机试题2Word文档下载推荐.docx_第3页
第3页 / 共35页
全国计算机二级C上机试题2Word文档下载推荐.docx_第4页
第4页 / 共35页
全国计算机二级C上机试题2Word文档下载推荐.docx_第5页
第5页 / 共35页
点击查看更多>>
下载资源
资源描述

全国计算机二级C上机试题2Word文档下载推荐.docx

《全国计算机二级C上机试题2Word文档下载推荐.docx》由会员分享,可在线阅读,更多相关《全国计算机二级C上机试题2Word文档下载推荐.docx(35页珍藏版)》请在冰豆网上搜索。

全国计算机二级C上机试题2Word文档下载推荐.docx

函数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

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 医药卫生 > 基础医学

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1