歷年計算機等級考試二級C語言上機真題及答案_第1頁
歷年計算機等級考試二級C語言上機真題及答案_第2頁
歷年計算機等級考試二級C語言上機真題及答案_第3頁
歷年計算機等級考試二級C語言上機真題及答案_第4頁
歷年計算機等級考試二級C語言上機真題及答案_第5頁
已閱讀5頁,還剩11頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)

文檔簡介

l.m個人的成績存放在score數(shù)組中,請編寫函數(shù)fun,它的功能是:將低

于平均分的人作為函數(shù)值返回,將低于平均分的分數(shù)放在below所指定

的函數(shù)中。

1.intfun(intscore[],intm,intbe1ow[])

{inti,k=0,aver=0;

for(i-0;i<m;i++)

aver+=score[i];

aver/=m;

for(i=0,i<m;i++)

if(score[i]<aver)

{below[k]=score[i];

k++;}

returnk;}

2.請編寫函數(shù)fun,它的功能是:求出1到100之內(nèi)能北7或者I1整除,但

不能同時北7和11整除的所有證書,并將他們放在a所指的數(shù)組中,通過

n返回這些數(shù)的個數(shù)。

2.voidfun(int*a,int*n)

{inti,j=0;

for(i=2;i<1000;i++)

if((i%7==0//i%ll==0))&i%77!=0)

a[j++卜i;

*n=j;}

3.請編寫函數(shù)voidfun(intx,intpp[],int*n),它的功能是:求出能

整除x且不是偶數(shù)的各整數(shù),并按從小到大的順序放在pp所指的數(shù)組

中,這些除數(shù)的個數(shù)通過形參n返回。

3.voidfun(intx,intpp[],int*n)

{inti=l,j=O,k=O,*t=pp;

for(i=();i<=x;i++)

if(i%2!=0)

{t[j]=i;

j++;}

for(i=0;i<j;i++)

if(x%t[i]==O)

{pp[k]=t[i];

k++;}

*n=k;}

4.請編寫一個函數(shù)voidfun(char*11,intpp[]),統(tǒng)計在tt字符中"a"到

”z”26各字母各自出現(xiàn)的次數(shù),并依次放在pp所指的數(shù)組中。

4.voidfun(char*11,intpp[])

{inti;

for(i=0;i<26;i++)

PP[i]=O;

while(*11)

{switch(*tt)

{case'a':pp[O]++;break;

case'b*:pp[1]++;break;

case,c':pp[2]++;break;

case'd,:pp[3]++;break;

case,e':pp[4]++;break;

case,f,:pp[5]++;break;

case'g':pp[6]++;break;

case,h,:pp[7]++;break;

case'i*:pp[8]4-4-;break;

case,j,:pp[9]++;break;

case'k':pp[1O]++;break;

case'r:pp[11]++;break;

case'm1:pp[12]++;break;

case*n':pp[I3]++;break;

case'o':pp[14]++;break;

case'p':pp[I5]++;break;

case1q1:pp[16]++;break;

case'r':pp[17]++;break;

case's':pp[18]++;break;

case'frppt19]++;break;

case,u,:pp[20]++;break;

case,v,:pp[21]++;break;

case'w':pp[22]++;break;

case,x,:pp[23]++;break;

case'y,:pp[24]++;break;

case'z':pp[25]++;break;}

tt++;}

)

5.請編寫一個函數(shù)voidfun(intm,intk,intxx[]),該函數(shù)的功能是:

將大于整數(shù)m且緊靠m的k各素數(shù)存入xx所指的數(shù)組中。

5.voidfun(intm,intk,intxx[])

{intg=O,i,j,flag=l;

for(i=m+1;i<m*m;i++)

{for(j=2;j<i;j++)

{if(i%j!=0)

flag=1;

else

{flag=0;

break;}

}

if(flag==1&j>=i)

{if(k>0)

{xx[g++]=i;

k--;)

else

break;}}}

6.請編寫一個函數(shù)voidfun(chara[],char[],intn),其功能是:刪除以

各字符串中指定下標的字符。其中,a指向原字符串,刪除后的字符串存

放在b所指的數(shù)組中,n中存放指定的下標。

6.voidfun(chara[],charb[],intn)

{inti,j=0;

for(i=0;i<LEN;i++)

if(i!=n)

{b[j]=a[i];

j++;}

b[j]=,\Of;}

7.請編寫一個函數(shù)intfun(int*s,intt,int*k),用來求除數(shù)組的最大

元素在數(shù)組中的下標并存放在k所指的儲存單元中。

7.voidfun(int*s,intt,int*k)

{inti,max;

max=s[0];

for(i=0;i<t;i++)

if(s[i]>max)

{max=s[i];

*k=i;}}

8.編寫函數(shù)fun,功能是:根據(jù)以下攻勢計算s,計算結(jié)果作為函數(shù)值返

回;n通過形參傳入。s=l+l/(l+2)+l/(l+2+3)+............+1/(1+2+3+4++

n)

8.floatfun(intn)

{inti;

floats=l.0,t=l.0;

for(i=2;i<=n;i++)

{t=t+i;

s=s+1/1;}

returns;}

9.編寫一個函數(shù)fun,它的功能是:根據(jù)以下公式求P的值,結(jié)果由函數(shù)

值帶回。m與n為兩個正整數(shù),且要求m>n。p=m!/n!(m-n)!

9.p=m!/n!(m-n)!

floatfun(intm,intn)

{floatp,t=1.0;

inti;

for(i=l;i<=m;i++)

t=t*i;

P=t;

for(t=1.0,i=l;i<=n;i++)

t=t*i;

p=p/t;

for(t=l.0,i=l;i<m-n;i++)

p=p/t;

returnp;}

10.編寫函數(shù)fun,它的功能是:利用以下的簡單迭代方法求方程cos(x)-

x=0的一個實根。

迭代步驟如下:(1)取xl初值為0.0;(2)x0=xl,把xl的值賦各x0;

(3)xl=cos(x0),求出一個新的x1;

(4)若x0-x1的絕對值小于0.000001,則執(zhí)行步驟(5),否則執(zhí)行步驟(2);

(5)所求xl就是方程cos(x)-x=0的一個實根,作為函數(shù)值返回。

程序?qū)⑤敵鯮oot=0.739085。

10.fo1atfun()

{floatx1=0.0,x0;

{x0=x1;

xl=cos(x0);}

while(fabs(x0-x1)>=1e-6)

returnx1;}

11.下列程序定義了NXN的二維數(shù)組,并在主函數(shù)中自動賦值。請編寫

函數(shù)fun(int該函數(shù)的功能是:使數(shù)組左下半三角元素中的值

全部置成0。

11.intfun(inta[][N])

{inti,j;

for(i=0;i<N;i++)

for(j=0;j<i;j++)

a[i][j]=O;}

12.下列程序定義了NXN的二維數(shù)組,并在主函數(shù)中賦值。請編寫函數(shù)

fun,函數(shù)的功能使求出數(shù)組周邊元素的平均值并作為函數(shù)值返回給主函

數(shù)中的s。

12.doub1efun(intw[][N])

{inti,j,k=O;

doubles=0.0;

for(j=O;j<N;j++)

{s+=w[0][j];

k++;}

(j=O;j〈N;j++)

[s+w[N-i][j];

k++;}

(i=1;i<=N-2;i++)

{s+=w[i][0];

k++;}

returns/=k;}

13.請編寫?個函數(shù)voidfun(inttt[M][N],intpp[N]),tt指向一個M

行N列的二維函數(shù)組,求出二維函數(shù)組每列中最小元素,并依次放入pp

所指定一維數(shù)組中。二維數(shù)組中的數(shù)已在主函數(shù)中賦予。

13.voidfun(inttt[M][N],intpp[N])

{inti,j,min;

for(j=O;j<N;j++)

{min=tt[0][j];

for(i=0;i<M;i++)

{if(tt[i][j]<min)

min=tt[i][j];}

pp[j]=min;}}

14.請別寫函數(shù)fun,函數(shù)的功能使求出二維數(shù)組周邊元素之和,作為函

數(shù)值返回。二維數(shù)組中的值在主函數(shù)中賦予。

14.intfun(inta[M][N])

{inti,j,s=0;

for(j=O;j<N;j++)

{s+=a[0][j];

s+=a[M-l][j];}

for(i=1;iv=M?2;i++)

{s+=a[i][0];

s+=a[i][N-l];)

returns;}

15.請編寫一個函數(shù)unsignedfun(unsignedw),w使一個大于10的無

符號整數(shù),若w使n(n22)位的整數(shù),則函數(shù)求出w后n—1位的數(shù)作為函

數(shù)值返回。

15.unsignedfun(unsignedw)

{unsignedt,s=0>sl=1,p=0;

t=w;

whi1e(t>10)

{if(t/l0)

p=t%10;

s=s+p*s1;

s1=s1*10;

t=t/10;}

returns;}

16.請編寫一個函數(shù)floatfun(doubleh),函數(shù)的功能使對變量h中的

值保留2位小樹,并對第三位進行四舍五入(規(guī)定h中的值位正數(shù))。

16.floatfun(fIoath)

{longt;

floats;

h=h*1000;

t=(h+5)/10;

s=(float)t/100.0;

returns;}

17.請編寫一個函數(shù)fun(char*s),該函數(shù)的功能使把字符串中的內(nèi)容

擬置。

17.voidfun(char*s)

{charch;

inti,m,n;

i=0;

m=n=strlen(s)-1;

while(i<(n+l)/2)

{ch=s[i];

s[i]=s[m];

s[m]=ch;

i++;

m--;})

18.編寫程序,實現(xiàn)矩陣(3行3列)的轉(zhuǎn)置(即行列互換)。

I8.voidfun(intarray[3][3])

{inti,j,temp;

for(i=0;i<3;i++)

{temp=array[i][j];

array[i][j]=array[j][i];

array[j][i]=temp;}}

19.編寫函數(shù)fun,該函數(shù)的功能是:從字符中刪除指定的字符,同一字母

的大、小寫按不同字符處理。

19.voidfun(chars[],intc)

{inti=0;

char*p;

P=s;

whi1e(*p)

{if(*p!=c)

{s[i]=*p;

i++;}

P++;}

s[i]='\0';}

20.編寫函數(shù)intfun(intIim,intaa[MAX]),該函數(shù)的功能是求出小于

或等于lim的所有素數(shù)并放在aa數(shù)組中,該函數(shù)返回所求的素數(shù)的個數(shù)。

20.intfun(int1im,intaa[MAX])

{intk=O,i,j;

for(i=lim;i>I;i--)

{for(j=2;j<i;j++)

if(i%j==O)

break;

else

continue;

if(j>=i)

{aa[k]=i;

k++;}}

returnk++;}

21.請編寫函數(shù)fun,對長度位7個字符的字符串,除首尾字符外,將其余

5個字符按ASCII碼降序排列。

21.voidfun(char*s,intnum)

{chart;

inti,j;

for(i=1;i<num-2;i++)

for(j=i+1;j<num-1;j++)

if(s[i]<s[j])

{t=s⑴;

s[i]=s[j];

s[j]=t;}}

22.N名學(xué)生的成績已在主函數(shù)中放入一個帶頭節(jié)點的鏈表結(jié)構(gòu)中,h指

向鏈表的頭節(jié)點。請編寫函數(shù)fun,它的功能是:找出學(xué)生的最高分,由

函數(shù)值返回。

22.doublefun(STREC*h)

{doublemax;

STREC*q=h;

max=h->s;

do

{if(q->s>max)

max=q->s;

q=q->next;}

while(q!=0);

returnmax;}

23.請編寫函數(shù)fun,該函數(shù)的功能是:判斷字符串是否為回文?若是則

函數(shù)返回1,主函數(shù)中輸出YES,否則返回0,主函數(shù)中輸出NO。回文是

指順讀和例讀都是一樣的字符串。

23.intfun(char*str)

{inti,n=0,fg=l;

char*p=str;

while(*p)

{n++;

P++;}

for(i=0;i<n/2;i++)

if(str[i]==str[n-1-i]);

else

{fg=o;

break;}

returnfg;}

24.請編寫一個函數(shù)fun,它的功能是:將一個字符串轉(zhuǎn)換為一個整數(shù)

(不得調(diào)用C語言提供的將字符串轉(zhuǎn)換為整數(shù)的函數(shù))。

24.longfun(char*p)

{longs=O,t;

inti=O,j,n=strlen(p),k,sl;

if(p[0]=='-?)

i++;

for(j=i;j<=n-I;j++)

{t=p[j]-'O';

sI=10;

for(k=j;k<n-l;k++)

t*=s1;

s+=t;}

if(p[0]=='-?)

return-s;

else

returns;}

25.請編寫一個函數(shù)fun,它的功能是:比較兩個字符串的長度,(不得調(diào)

用C語言提供的求字符串長度的函數(shù)),函數(shù)返回較長的字符串。若兩個

字符串長度相同,則返回第一個字符串。

25.char*fun(char*s,char*t)

{char*p,*t1=t,*s1=s;

intn=0,m=0;

whiIe(*s1)

{n++;

s1++;}

whiIe(*t1)

{m++;

tl++;}

if(n>=m)

P=s;

else

P=t;

returnp;}

26.請編寫一個函數(shù)fun,它的功能是:根據(jù)以下公式求X的值(要求滿足

精度0.0005,即某項小于0.0005時停止迭代):

X/2=l+l/3+lx2/3x5+lx2x3/3x5x7+lx2x3x4/3x5x7x9+…+Ix2x3x...xn/

3x5x7x(2n+1)

程序運行后,如果輸入精度0.0005,則程序輸出為3.14...。

26.doublefun(doubleeps)

{doubles;

floatn,t,pi;

t=1;pi=0;n=l.0;s=l.0;

while((fabs(s))>=cps)

{pi+=s;

t=n/(2*n+1);

s*=t;

n++;}

pi=pi*2;

returnpi;}

27.請編寫一個函數(shù)fun,它的功能是:求除1到m之內(nèi)(含m)能北7或11

整除的所有整數(shù)放在數(shù)組a中,通過n返回這些數(shù)的個數(shù)。

27.voidfun(intm,int*a,int*n)

{inti,j;*n=O;

for(i=1;i<=m;i++)

if(i%7==0//i%11==0)

{a[j]=i;

j++;}

*n=j;}

28.請編寫一個函數(shù)fun,它的功能是:找出維整型數(shù)組元素中最大

的值和它所在的下標,最大的值和它所在的下標通過形參傳回。數(shù)組元

素中的值已在主函數(shù)中賦予。主函數(shù)中x是數(shù)組名,n是x中的數(shù)據(jù)個

數(shù),max存放最大值,index存放最大值所在元素的下標。

28.voidfun(inta[],intn,int*max,int*d)

{inti;

*max=a[0];

*d=0;

for(i=0;i<n;i++)

if(a[i]>*max)

{*max=a[i];

=}

29.請編寫一個函數(shù)fun,它的功能是:將ss所指字符串中所有下標為奇

數(shù)位置上的字母轉(zhuǎn)換為大寫(若該位置上不是字母,則不轉(zhuǎn)換)。

29.voidfun(char*ss)

{inti,n;

n=strlen(ss);

for(i=1;i<n;i+=2;)

if(ss[i]>='a,&&ss[i]<=,z,)

ss[i]=ss[i]-32;}

30.請編寫一個函數(shù)fun,它的功能是:求除一個2XM整型二維數(shù)組中

最大元素的值,并將此值返回調(diào)用函數(shù)。

30.intfun(inta[][M])

{inti,j,max;

max=a[0][0];

for(i=0;i<2;i++)

for(j=0;j<M;j++)

if(a[i][j]>max)

max=a[i][j];

returnmax;}

31.請編寫函數(shù)fun,其功能是:將s所指字符串中除了下標為偶數(shù)、同時

ASC11值也為偶數(shù)的字符外,其余的全都刪除;串中剩余字符所形成的一

個新串放在t所指的一?個數(shù)組中。

31.voidfun(char*s,chart[])

{inti,j,n;

n=strlen(s);

for(i=0;i<n;i++)

if(i%2==0&s[i]%2==0)

{t[j]=s[j];

j++;}

32.請編寫函數(shù)fun,其功能是:將s所指字符串中除了下標為奇數(shù)、同時

ASCI【值也為奇數(shù)的字符之外,其余的所有字符都刪除,串中剩余字符所

形成的一個新串放在t所指的一個數(shù)組中。

32.voidfun(char*s,chart[])

{inti,j=O,n;

n=strlen(s);

for(i=0;i<n;i++)

if(i%2!=0&s[i]%2!=0)

{t[j]=s[j];

j++;}

33.假定輸入的字符串中只包含字母和*號。請編寫函數(shù)fun,它的功能

是:使字符串中尾部的*號不得多于n個;若多于n個,則刪除多于的*

號;若少于或等于n個,則什么也不做,字符串中間和前面的*號不刪除。

33.voidfun(char*a,intn)

{inti=0,k=0;

char*p,*t;

p=t=a;

whi1e(*t)

t++;

t--;

{k++;

"?;}

t++;

if(k>n)

{while(*p&p<t+n)

{a[i]=*p;

i++;

P++;}

a[i]=,\0';}}

34.學(xué)生的記錄由學(xué)號和成績組成,N名學(xué)生的數(shù)據(jù)已在主函數(shù)中放入

結(jié)構(gòu)體數(shù)組s中,請編寫函數(shù)fun,它的功能使:把分數(shù)最高的學(xué)生數(shù)據(jù)

放在h所指的數(shù)組中,注意:分數(shù)最高的學(xué)生可能不止一個,函數(shù)返回分

數(shù)最高的學(xué)生的人數(shù)。

34.intfun(STREC*a,STREC*b)

{inti,j=0,max;

max=a[0].s;

for(i=0;i<N;i++)

if(a[i].s==max)

{*(b+j)=a[i];

j++;

n++;}

returnn;}

35.請編寫一個函數(shù),用來刪除字符串中的所有空格。

35.voidfun(char*str)

{inti=0;

char*p=str;

whi1e(*p)

{if(*p!=")

{str[i]=*p;

i++;}

P++;}

str[i]=,\O';}

36.假定輸入的字符串中只包含字母和*號。請編寫函數(shù)fun,它的功能

是:將字符串中的前導(dǎo)*號全部移到字符串的尾部。

36.voidfun(char*a)

{inti=0,n=0;

char*p;

p=a;

while(*p=='*')

{n++;

P++;}

while(*p)

{a[i]=*P;

i++;

P++;}

while(n!=0)

{a[i]=,*1;

i++;

i--;}

a[i]='\0';}

37.某學(xué)生的記錄由學(xué)號、8門課程成績和平均分組成,學(xué)號和8門課程

的成績已在主函數(shù)中給出。請編寫函數(shù)fun,它的功能是:求出該學(xué)生的

平均分放在記錄的ave成員中。請白己定義正確的形參。

37.voidfun(STREC*p)

{doubleav=0.0;

inti;

for(i=0;i<N;i++)

av+=p->s[i];

av/=N;

p->ave=av;}

38.請編寫函數(shù)fun,它的功能是:求出ss所指字符串中指定字符的個

數(shù),并返回此值。

38.intfun(char*ss,charc)

{intn=0;

while(*ss)

{if(*ss==c)

n++;

ss++;}

returnn;}

39.請編寫函數(shù)fun,該函數(shù)的功能是:移動一維數(shù)組中的內(nèi)容,若數(shù)組

中由n個整數(shù),要求把下標從0到p(p小于等于n-l)的數(shù)組元素平移到

數(shù)組的最后。

39.voidfun(int*w,intp,intn)

{intb[N],i,j=0;

for(i=0;i<=p;i++)

b[i]=w[i];

for(i=p+1;i<n;i++)

{w[j]=w[i];

j++;}

for(i=0;i<=p;i++)

{w[j]=b[i];

j++;}}

40.請編寫函數(shù)fun,該函數(shù)的功能是移動字符串中內(nèi)容,移動的規(guī)則如

卜:把第1到第m個字符,平移到字符串的最后,把第m+1到最后的字符

移到字符串的前部。

40.voidfun(char*w,intm)

{charb[N];

inti,j=0;

for(i=0;i<m;i++)

{b[j]=w[i];

j++;}

for(i=0;i<strlen(w)-m;i++)

w[i]=w[i+m];

for(j=0;j<m;j++)

{w[i]=b[j];

i++;}

w[i]=,\0,;}

41.請編寫函數(shù)fun,該函數(shù)的功能是:將M行N列的二維數(shù)組中的字

符數(shù)據(jù),按列的順序依次放到一個字符串中。

41.voidfun(char(*s)[N],char*b)

{inti,j,k=O;

for(j=0;j<n;j++)

for(i=0;i<M;i++)

{b[k]=*(*(s+i)+j)

k++;}

b[k]='\O';}

42.下列程序定義了NXN的二維數(shù)組,并在主函數(shù)中自動賦值。請編寫

函數(shù)fun(inta[][N],intm),該函數(shù)的功能是:將數(shù)組右上半三角元素中

的值乘以m。

42.voidfun(inta[][N],intm)

{inti,j;

for(j=0;j<N;j++)

for(i=0;i<=j;i++)

a[i][j]=a[i][j]*m;}

43.編寫一個函數(shù),從傳入的num個字符串中找出一個最長的一個字符

串,并通過形參指針max傳回該串地址(用****作為結(jié)束輸入的標志)。

43.char*fun(char(*a)[8I],intnum)

{inti;

char*max;

max=a[0];

for(i=0;i<num;i++)

if(strlen(max)<strlen(a[i]))

max=a[i];

returnmax;}

44.編寫一個函數(shù),該函數(shù)可以統(tǒng)計一個長度為2的字符串在另一個字

符串中出現(xiàn)的次數(shù)。

44.intfun(char*str,char*substr)

{intn;

char*p,*r;

n=0;

while(*str)

{P=str;

r=substr;

vvhi1e(*r)

if(*r==*p)

{r++;

p++;}

else

break;

if(*r==*\O,)

n++;

str++;}

returnn;}

45.假定輸入的字符串中只包含字母和*號。請編寫函數(shù)fun,它的功能

是:只刪除字符串前導(dǎo)和尾部的*號,串中字母之間的*號都不刪除。形

參n給出了字符串的長度,形參h給出了字符串中前導(dǎo)*號的個數(shù),形參

e給出了字符串中最后的*個數(shù)。在編寫時不得使用C語言給提供得字符

串函數(shù)。

45.voidfun(char*a,intn,inth,inte)

{inti=0;

char*p;

for(p=a+h;p〈a+n-e;p++)

{*(a+i)=*p;

i++;}

*(a+i)='\O';}

46.學(xué)生得記錄由學(xué)號和成績組稱個,N名大學(xué)生得數(shù)據(jù)已在主函數(shù)中

放入結(jié)構(gòu)體數(shù)組s中,請編寫函數(shù)fun,它的功能時:按分數(shù)的高低排列

學(xué)生的記錄,高分在前。

46.voidfun(STRECa[])

{inti,j;

STRECt;

for(i=0;i<N-1;i++)

f

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
  • 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論