2021年河南省商丘市全國計算機等級考試C語言程序設計真題(含答案)_第1頁
2021年河南省商丘市全國計算機等級考試C語言程序設計真題(含答案)_第2頁
2021年河南省商丘市全國計算機等級考試C語言程序設計真題(含答案)_第3頁
2021年河南省商丘市全國計算機等級考試C語言程序設計真題(含答案)_第4頁
2021年河南省商丘市全國計算機等級考試C語言程序設計真題(含答案)_第5頁
已閱讀5頁,還剩36頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

2021年河南省商丘市全國計算機等級考試

C語言程序設計真題(含答案)

學校:班級:姓名:考號:

一、2.填空題(10題)

1.下列程序的輸出結果是【】。

main()

{inti;

for(i=l;i+1;i++)

{if(i>4)

{printf("%d\n",i);

break;}

printf("%d\n",i++);}}

2.在面向對象方法中,類的實例稱為o

3.已知字母A的ASCII碼為65。以下程序運行后的輸出結果是()。

main()

{chara,b;

a='A'+'5'-'3';b=a+'6'-'2';

a='A'+'5'-'3';b=a+'6'-'2';

printf("%d%c\n",a,B);

4.以下程序的輸出結果是()。

#include<stdio.h>

main()

{intx=27;

while(x>20&&x<30)

{x++;

if(x/3){x++;break;}

else

continue;

)

printf("%d\n",x);

)

5.以下fun函數的功能是:累加數組元素中的值,n為數組中元素的個

數,累加的和值放入x所指的存儲單元中。請?zhí)羁铡?/p>

fun(intb[],intn,int*x)

{intk,r-0;

for(k=0,k<n;k++)r=[];

[]=r;

)

6.以下程序的輸出結果是[]o

#include<stdlib.h>

main()

{char*sl,*s2,m;

s1=s2=(char*)malloc(sizeof(char));

*sl=15;*s2=20;m=*sl+*s2;

printf("%d\n",m);

7.長度為n的順序存儲線性表中,當在任何位置上插入一個元素概率

都相等時,插入一個元素所需移動元素的平均個數為【】。

8.下面的程序可對指定字符串中的字符串進行從大到小排序,請將程序

填完整。(注:程序采用了冒泡排序法)

#include<stdio.h>

#include<string.h>

main()

{char*str="ABCDabcd",temp;

intn,i;

n=strlen(str);

while(n—>1)

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

if(str[i]<str[i+l])

{temp=[];

str[i]=str[i+l];

[]=temp;

)

printf([]);

)

9.子程序通常分為兩類:[]和函數,前者是命令的抽象,后者是為了

求值。

10.若a是血型變量,且a的初值為4,則計算a+=a-=a*a表達式后a

的值為O

二、單選題(10題)

11.

A.*sB.sC.*s++D.(*s)++

12.下列寫法正確的是()。

A.main(){inti=3,j;j=5}

B.main(){inti=3;

C.main()

D.main(){;}

(25)判斷char型變量cl是否為小寫字母的iE確表達式為().

A)n<=€1<=/B)(cl>=a)&&(cl<=z)

C)('a'>=cl||Cz,v=cl)D)(cl>='a')&&(cl<='z')

20)有下列程序,其中%u表示按無符號整數輸出。

main()

{unsignedintx=OxFFFF;/*x的初值為十六進制數*/

printf("%u\n",x);

)

程序運行后的輸出結果是().

A)-1B)65535

14.C)32767D)OxFFFF

15.用數組r存儲靜態(tài)鏈表,結點的next域指向后繼,工作指針j指向鏈

中結點,使j沿鏈移動的操作為0。

A.j=r[j].nextB.j=j+1C.j=j->nextD.j=r[j]->next

16.常采用的兩種存儲結構是()。

A.順序存儲結構和鏈式存儲結構B.散列方法和索引方式C.鏈表存儲

結構和數組D.線性存儲結構和非線性存儲結構

17.為了使模塊盡可能獨立,要求。

A.模塊的內聚程度要盡量高,且各模塊間的耦合程度要盡量強

B.模塊的內聚程度要盡量高,且各模塊間的耦合程度要盡量弱

C.模塊的內聚程度要盡量低,且各模塊間的耦合程度要盡量弱

D.模塊的內聚程度要盡量低,且各模塊間的耦合程度要盡量強

18.有以下程序段:

charstr[4][12]={“aaa”,“bbb”,“ccc”,“ddd"},*p[4];

inti;for(i=0;i<4;i++)p[i]=str[i];

以下選項中不能正確引用字符串的是()。

A.*p[3]B.p[3]C.str[2]D.*p

19.下列關于效率的說法不正確的是()

A.效率是一個性能要求,其目標應該在需求分析時給出

B.提高程序效率的根本途徑在于選擇良好的設計方法,數據結構與算法

C.效率主要指處理機時間和存儲器容量兩個方面

D.程序的效率與程序的簡單性無關

20.對長度為n的無序線性表進行順序查找,則查找成功、不成功時的平

均數據比較次數分別為()。

A.n/2,nB,n+l/2,n-lC.n+l/2,nD.n-l/2,n-l

三、程序設計題(10題)

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

能是:將字符串尾部的*號全部刪除,前面和中間的*號不刪除。例如,

若字符串中的內容為****a*bc*def*g。***,刪除后,字符串中的內容則

應當是****a*bc*def*g。注意:部分源程序給出如下。請勿改動主函

數main和其他函數中的任何內容,僅在函數proc的花括號中填入所編

寫的若干語句。試題程序:

£tnciudch>

votdpraHchdif?*tr>

voidnuun?>

HuirJi

prmtfC'FnuraMnngt\na)?

proc(t

pnntf<7而.afterdeletedi\n")t

22.編寫函數fun(),其功能是計算:

S作為函數值返回。

在C語言中可調用log(n)函數求ln(n)olog函數的引

用說明為:doublelog(doublex)。

例如,若m的值為20,則fun()函數值為6.506583。

注意:部分源程序給出如下。

請勿改動main()函數和其他函數中的任何內容,僅在函數fun()的花括

號中填入你編寫的若干語句。

試題程序:

9mcludcVadhhh>

gincludeVcons0t

9include

9tncludrVath.bA

lioublelun<mltB>

raidmain()

("CLS")i

prifith(\nM?fun<20)):

23.請編寫函數proc,該函數的功能是:將M行N列的二維數組中的

數據,按行的順序依次放到一維數組中,一維數組中數據的個數存放

在形參n所指的存儲單元中。

例如,若二維數組中的數據為

13233343

14243444

15253545

則一維數組中的內容應該是132333431424344415253545。

注意:部分源程序給出如下。

請勿改動main函數和其他函數中的任何內容,僅在函數proc的花括

號中填入所編寫的若干語句。

試題程序:

#include<stdio.h>

voidproc(int(*s)[103,int*b,int*n,intrain,intnn)

(

)

voidmain

(

intarr[10][10]={{33,33,33,33),{44,44,44,44},

{55,55,55,55}),i,j;

inta[100]={o),n=o;

printf("Thematrix:\n");

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

(

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

printf("%3d",arr[i][j]):

printf("\n");

)

proc(arr,a,&n,3,4):

printf("TheAarray:\n");

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

printf("%3d",a[i]):

printf("\n\n");

24.請編寫一"函數voidproc(char*tt,intpp[]),統(tǒng)計在tt字符串中“a”

到“z”26個字母各自出現的次數,并依次放在pp所指數組中。例如,

當輸入字符串abcdefghxyzabcde"e后,程序的輸出結果應該是:

222233110000000000000000111o注意:部分源程序給出如下。請勿改

動main()函數和其他函數中的任何內容,僅在函數proc()的花括號

中填入所編寫的若干語句。試題程序:

/include

fiinclude<xdia.h2>

*iheiudeV儀dhhh>

voidproc<char?tt?mtJ)

votdnuitni1

char

mi

prtntfl*\DPIM?<enter?chari

proc<

loc(k-0ik<2<i?)

pmtf(*Kd.?bKli]》i

a)!

25.

請編寫一個函數proc(),它的功能是:求出一個4xN整型二維數組中

最大元素的值,并將此值返回調用函數。注意:部分源程序給出如下。

請勿改動main()函數和其他函數中的任何內容,僅在函數proc的花

括號中填入所編寫的若干語句。試題程序:

=deGneN4

sincludrh>

intan{l][N'L”.lL5.53.2?42?-32?九

81.-3S.3.3463?-9h

pnntf(9nuMsHtf\n*.proe<ArT))s

26.使用VC++2010打開考生文件夾下析progl中的解決方案。此解決

方案的項目中包含一個源程序文件progl.c。在此程序中,請編寫函數

fun(),它的功能是計算下列級數和,和值由函數值返回。

23M

S=1?X+工+<+.??+工

,■2!3!”!例如,當n=10,x=0.3時,函數值為

1.349859。注意:部分源程序在文件progl.c中。請勿改動主函數

main()和其他函數中的任何內容,僅在函數fun()的花括號中填入你編

寫的若干語句。試題程序:

1#include<conio.h>

2#include<stdio.h>

3tinclude<math.h>

4finclude<stdlib.h>

5doublefun(doublex,intn)

6{

7

8)

9voidmain()

10{

11FILE*wf;

12system(MCLSW);

13printf(w%ffun(0.3,10));

14/*****************/

15wf工fopen("out.daf\MwH);

w

16fprintf(wfz%f"rfun(0.3,10));

17fclose(wf);

18/*****************/

19)

27.

假定輸入的字符串只包含字母和“#”號,請編寫函數fun(),它的功能

是:刪除字符串中所有的“#”號。在編寫函數時,不得使用C語言提供

的字符串函數。例如,若字符串中的內容為“##w#el##come###",刪除

后,字符串中的內容則應當是“welcome”。請勿改動main()函數與其

他函數中的任何內容,僅在函數fun()的花括號中填入所編寫的若干

語句。試題程序:

Winclude<?tdio.h>

#include<conio.h>

#definestrepy

voidfun(char?s)

voidmain()

<

charstr£81J:

FILE?out:

printfC*Entcras(rin^;\n*)j

gets(str)i

fun(5ir)i

printfC"Thestringafterdeleted:\n");

puts(str)i

out—fopen<"oulfile.datw>*w")i

strcpy(str.**t?#sTsES*T####W#與"):

fun(str)?

fpnnt((out.*%s*.sir)?

klosv<out):

28.

請編寫函數proc(),該函數的功能是:將放在字符串數組中的M個字

符串(每串的長度不超過N).按順序合并組成一個新的字符串。例如,

若字符串數組中的M個字符串為:ABCDBCDEFGCDEFGHI則合并

后的字符串內容應該是:ABCDBCDEFGCDEFGH1o注意:部分源程

序給出如下。請勿改動main()函數和其他函數中的任何內容,僅在

函數proc()的花括號中填入所編寫的若干語句。試題程序:

*tududeVzdq.h>

dincludeVeonao.h>

9defineM3

94rfitwN20

voidproc<char.FT:Ml[N<char?b>

voidai,4)

cUrMrQMJLN]?(*AMT)-.*K'DEFcr.*

C-DEFGHn.ii

chararrfIOO]?C9999999999999

■,■?■?)1

pnoifieThe?mngt\D*>i

pvu(

prmih*\ne>i

proc(*tr?arT>g

prwid("TheAMnng;\n*)>

pnntf(*Ms

pnn<f<M\n\n*><

29.使用VC++2010打開考生文件夾下progl中的解決方案。此解決方

案的項目中包含一個源程序文件progl.c。在此程序中,學生的記錄由學

號和成績組成,N名學生的記錄已在主函數中放入結構體數組s中,請

編寫函數fun(),其功能是把低于平均分的學生記錄放入b所指的數組

中,低于平均分的學生人數通過形參n返回,平均分通過函數值返回。

注意:部分源程序給出如下。

請勿改動主函數main()和其他函數中的任何內容,僅在函數fun()的花

括號中填入你編寫的若干語句。

試題程序:

#include<stdio.h>

#defineN8

typedefstruct

(

charnum[10];

doubles;

JSTREC;

doublefun(STREC*a,STREC*b,int*n)

voidmain()

(

STRECs[N]={{"GA05”,85},{“GA03”,76},{“GA02”,69},{“GA04”,

85},{“GAO1”,91},{“GA07”,72},{“GA08”,64},{“GA06”,87}};

STRECh[N];

inti,n;

doubleave;

ave=fun(s,h,&n);

printff'The%dstudentdatawhichislowerthan%7.3f:\n^^,n,ave);

for(i=0;i<n;i++)<p=""x/n;i++)<>

/*輸出成績低于平均分的學生記錄*/

printf("%s%4.1f\n^^,h[i].num,h[i].s);

printf

30.使用VC++2010打開考生文件夾下progl中的解決方案。此解決方

案的項目中包含一個源程序文件progl.c。在此程序中,規(guī)定輸入的字符

串中只包含字母和*號。編寫函數fun(),其功能是刪除字符串中所有的

*號。編寫函數時,不得使用C語言提供的字符串函數。

例如,字符串中的內容為“****A*BC*DEF*G*******”,刪除后,字符

串中的內容應當是“ABCDEFG”。

注意:部分源程序給出如下。

請勿改動主函數main()和其他函數中的任何內容,僅在函數fun()的花

括號中填入你編寫的若干語句。

試題程序:

#include<conio.h>

#include<stdio.h>

voidfun(char*a)

voidmain()

(

chars[81];

printf^Enterastring:\n");

gets(s);

fun(s);

printf("Thestringafterdeleted:\n");

puts(s);

四、2.程序修改題(10題)

31.給定程序M0D11.C中函數fun的功能是:求整數x的y次方的低

3位值。例如,整數5的6次方為15625,此值的低3位值為625。

請改正函數fun中指定部位的錯誤,使它能得出正確的結果。

注意:不要改動main函數,不得增行或刪行,也不得更改程序的結構!

;linclude<stdio.h>

2!longfun(intxrinty,long*p)

3i{inti;

4longt?l;

5I/*****★★???*??found*************/

i

6for(i-1;i<y;i++)

7

8*p-t;

9;/……?……found…………?/

10t-t/1000;

11returnt;

12

13main()

14{longt,r;intx,y;

15printf(M\nlnputxandy:H);

scanf(w%ld%ldw,&x,&y);

16t-fun(xry,&r);

H

17printf(\n\nx-?%dry-%d,r-%ldr

w

last?%ld\n\nrxryrr,t);

18

32.在主函數中從鍵盤輸入若干個數放入數組中,用。結束輸入并放在

最后一個元素中。下列給定程序中,函數fun()的功能是計算數組元素中

值為負數的平均值(不包括0)。

例如:數組中元素的值依次為43,47,-21,53,-8,12,0,則程序的

運行結果為-25.333333。

請改正程序中的錯誤,使它能得到正確結果。

注意:不要改動main函數,不得增行或刪行,也不得更改程序的結構。

試題程序:

#include<conio.h>

#include<stdio.h>

doublefun(intx[])

doublesum=0.0;

intc=0,i=0;

/*************^Qund*************I

while(x[i]==0)

if(x[i]<0)

sum=sum+x[i];

C++;

i++;

/************^Qund***********/

sum=sum\c;

returnsum;

main()

intx[1000];

inti=0;

clrscr();

printf("\nPleaseentersomedata(endwith

0):“);

do

scanf("%d",&x[i]);

}while(x[i++]!=0);

printf("%fm",fun(x));

)

33.給定程序M0D11.C中函數fun的功能是:根據輸入的三個邊長(整

型值),判斷能否構成三角形:構成的是等邊三角形,還是等腰三角形。

若能構成等邊三角形函數返回3,若能構成等腰三角形函數返回2,若

能構成一般三角形函數返回1,若不能構成三角形函數返回0。

請改正函數fun中指定部位的錯誤,使它能得出正確的結果。

注意:不要改動main函數,不得增行或刪行,也不得更改程序的結構!

linclude<stdio.h>

2?include<math.h>

3/???,.★★★★????found..

4voidfun(inta,intbrintc)

5(if(a+b>c&&b+c>a&&a*c>b){

6if(aMb&&bMC)

7return3;

8elseif(a==b|Ib?-cl|aMC)

9return2;

10/……….ffound★…………/

11elsereturn1

12I

13elsereturn0;

14i)

15main()

16{intarbrcrshape;

w

17printf(\nlnputa,brc:scanf

w

(-%d%d%dr4ar

w

18printf(\na-%d/b=%d,c?%d\n"r

a,b,c);

19shape?fun(arbrc);

w

20printf(\n\nTheshape:%d\n*r

shape);

21}

34.下列給定程序中,函數fun()的功能是:從N個字符串中找出最長的

那個中,并將其地址作為函數值返回。各字符串在主函數中輸入,并放

入一個字符串數組中。

請改正程序中的錯誤,使它能得出正確的結果。

注意:不要改動main函數,不得增行或刪行,也不得更改程序的結構。

試題程序:

#include<string.h>

#include<stdio.h>

#defineN5

#defineM81

/*************^Qund**************I

fun(char(*sq)[N])

{inti;char*sp;

sp=sq[0];

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

if(strlen(sp)<strlen(sq[i]))

sp=sq[i];

/*************^Qund**************/

returnsq;

main()

{charstr[N][M],*longest;inti;

printf("Enter%dlines:\n",N);

for(i=0;i<N;i++)gets(str[i]);

printf("\nThe%dstring:\n",N);

for(i=0;i<N;i++)puts(str[i]);

longest=fun(str);

printf("\nThelongeststring:\n");

puts(longest);

35.下列給定程序中,函數fun()的功能是:統(tǒng)計字符串substr在字符串

srt中出現的次數。例如,若字符串為aaas1kaaas,子字符串為as,則

應輸出2。

請改正程序中的錯誤,使它能得出正確的結果。

注意:不要改動main函數,不得增行或刪行,也不得更改程序的結構。

試題程序:

#include<stdio.h>

fun(char*str,char*substr)

{inti,j,k,num=0;

/*************^Qund**************I

for(i=0,str[i],i++)

for(j=i,k=0;substr[k]==str[j];k++,j++)

if(substr[k+l]=='\0')

{num++;

break;

)

returnnum;

)

main()

{charstr[80],substr[80];

printf("Inputastring:");

gets(str);

printf("Inputasbustring:");

gets(substr);

printf("%d\n",fun(str,substr));

36.下列給定程序中,函數fun()的功能是找出100?n(n不大于1000)之

間百位數字加十位數字等于個位數字的所有整數,把這些整數放在s所

指的數組中,個數作為函數值返回。

請改正程序中的錯誤,使它能得到正確結果。

注意:不要改動main函數,不得增行或刪行,也不得更改程序的結構。

試題程序:

#include<stdio.h>

#defineN100

intfun(int*s,intn)

inti,j,k,a,b,c;

j=0;

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

/*************^Qund***********/

k=n;

a=k%10;

k/=10;

b=k%10;

c=k/10;

if(a==b+c)

/************^Qund*********,

s[j]=i;

)

returnj;

)

main()

(

inta[N],n,num=0,i;

do

(

printf("\nEntern(<=1000):,,);

scanf("%d",&n);

while(n>1000);

num=fun(a,n);

printf("\n\nTheresult:\n");

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

printf("%5d",a[i]);

printf("\n\n");

)

37.給定程序MODU.C中函數fun的功能是:計算n的5次方的值(規(guī)

定n的值大于2、小于8),通過形參指針傳回主函數;并計算該值的個

位、十位、百位上數字之和作為函數值返回。

例如,7的5次方是16807,其低3位數的和值是15。

請改正函數fun中指定部位的錯誤,使它能得出正確的結果。

注意:不要改動main函數,不得增行或刪行,也不得更改程序的結構!

1?tinclude<stdio.h>

2iIinclude<math.h>

3intfun(intn,int*value)

4{intdrs,i;

5/???■foundrmf*/

6d-0;s-0;

7for(i?l;i<?5;i++).d?d?n;

8*value-d;

9for(i?l;i<-3;i++)

10{sms*d%10;

11

12d-d\10;

13

14returns;

15

16main()

17(intn,sum,v;

18do

19;{printf(w\nEntern(2<n<8):n);

(scanf("%dn,&n);)

20iwhile(n<-2||n>-8);

21sum?fun(n,&v);

22printf(w\n\nTheresults\nvalue*

%dsum-%d\n\n"rv,sum);

23

38.給定程序MOD11.C中函數fun的功能是:從整數1到55之間,選

出能被3整除、且有一位上的數是5的那些數,并把這些數放在b所指

的數組中,這些數的個數作為函數值返回。規(guī)定,函數中al放個位數,

a2放十位數。

請改正程序中的錯誤,使它能得出正確結果。

注意:不要改動main函數,不得增行或刪行,也不得更改程序的結構。

1tinclude<stdio.h>

2intfun(int*b)

3{intk,alra2ri-0;

4for(k-10;k<?55;k++){

5**?**?**

6a2-k/10;

7al-k-a2*10;

8if((k%3??0&&a2??5)||(k%3?-0

al35))

9(b(i]?k;)

10

★?………?found

12returnk;

13

14main()

15(inta(100],k,m;

16m?fun(a);

17printf(wTheresultis:\nw);

w

18for(k=0;k<m;k++)printf(%4d"r

a[k]);printf

19)

39.給定程序M0D11.C中函數fun的功能是:判斷一個整數是否是素

數,若是返回1,否則返回0。

在mai()函數中,若fun返回1輸出YES,若fun返回。輸出NO!。

請改正程序中的錯誤,使它能得出正確的結果。

注意:不要改動main函數。不得增行或刪行,也不得更改程序的結構!

1j*include<stdio.h>

2;intfun(intm)

3{intk-2;

4while(k<?m&&(m%k))

5i/?……?…*found…………/

6i

7i…………found…………

8Iif(m-k)

9jreturn1;

101elsereturn0;

11!

12(;main()

13;{intn;

14!printf(w\nPleaseentern:

wR

iscanf(%dr&n);

15if(fun(n))printf(MYES\n");

16elseprintf(WNO!\nn);

17

40.下列給定程序中,函數fun()的功能是:在字符串str中找出ASCII

碼值最大的字符,將其放在第一個位置上,并將該字符前的原字符向后

順序移動。例如,調用fun()函數之前給字符串輸入ABCDeFGH,調用

后字符串中的內容為eABCDFGHo

請改正程序中的錯誤,使它能得出正確的結果。

注意:不要改動main函數,不得增行或刪行,也不得更改程序的結構。

試題程序:

#include<stdio.h>

/***************found************I

fun(char*p)

{charmax,*q;inti=0;

max=p[i];

while(p[i]!=0)

{if(max<p[i])

/***************found************/

p=q+i;max=p[i];

i++;

/***************found************I

while(q<p)

{*q=*(q-l);

q--;

)

p[0]=max;

)

main()

{charstr[8O];

printf("Enterastring:");gets(str);

printf("\nTheoriginalstring:");

puts(str);

fun(str);

printf("\nThestringaftermoving:");

puts(str);printf("\n\n");

五、程序改錯題(2題)

41.下列給定程序中函數fun的功能是:將■所指字符串中的小寫字母全

部改為對應的大寫字母,其他字符不變。

例如,若輸入“Ab,cD",則輸出“AB,CD”。

請改正程序中的錯誤,使它能得出正確的結果。

注意:部分源程序在文件M0DI1.C中,不得增行或刪行,也不得更改

程序的結構!

tinclude<飄dio.h>

tinclude<string.h>

char?fun(charli[])

I

inti;

fbr(ix0;tt[i]ji??)

/found???????????/

if((V<?tt[i])11(lt[i]<=))

/found???????????/

ll[i]4=32;

return(tt);

I

main()

chartt[81];

printf(*\nP!e<Menterastring:w)?

geta(tt);

printf("\nTheresultstringit:\n%B",fun(tt));

42.

下列給定程序中,函數proc()的功能是:計算并輸出下列級數的前N

項之和SN,直到SN+1大于q為止。q的值通過形參傳人。SN=2/1+3

/2+4/3+(N+l)/N例如,若q的值為57,則函數值為59.593612。

請修改程序中的錯誤,使它能得出正確的結果。注意:不要改動main

()函數,不得增行或刪行,也不得更改程序的結構。試題程序:

:indudtVfitcUib.

拿inHutlr〈cooio.b>

SindudeVntdxxh>

/'/????????

doubleproc<doultlrq>

inimdouble

0i

whik<?um<

//????IOUM)????

sum*-sumXn>I)/nt

■+4?

//????fouM????

ElseMieni

voidm*in(>

*CLS*)i

pnntf(*Sl\n??proc?8)).

六、操作題(2題)

43.給定程序中,函數fun的功能是:調用隨機函數產生20個互不相同

的整數放在形參a所指數組中(此數組在主函數中已置0)。

請在程序的下劃線處填入正確的內容并把下劃線刪除,使程序得出正確

的結果。

注意:源程序存放在考生文件夾下的BLANK1.C中。

不得增行或刪行,也不得更改程序的結構!

1?include<stdlib.h>

2finclude<stdio.h>

3tdefineN20

4voidfun(int*a)

5(int1,x,n-0;

6x-rand()%20;

7/………”ound

8while(n<_1_)

9(for(i?0;i<n;i++)

10/???***?***found**?***?***/

11if(x-a[i])_2_;

12/………round………?/

13if(i-_3_)(a[n]?x;)

14xsrand()%20;

15

16

17main()

18intx[N)-(0)ri;

19fun(x);

20printf(wTheresult:\nw);

21for(iw0;i<N;i++)

wn

22(printf(%4drx[i]);

23if((i+1)%5??0)printf(H\nw);

24)

25printf(w\n\nw);

26

44.請編寫函數fun,它的功能是:計算并輸出n(包括n)以內能被5或9

整除的所有自然數的倒數之和。

例如,在主函數中從鍵盤給n輸入20后,輸出為:s=0.583333o注

意:要求n的值不大于100o

部分源程序在文件PROGLC中。

請勿改動主函數main和其他函數中的任何內容,僅在函數fun的花括

號中填入你編寫的若干語句。

1:linclude<stdio.h>

2doublefun(intn)

3

4

5

6NONO()

7(/?請在此函數內打開文件,輸入測試數據.

調用fun函畋,轆出數據.關閉文件.?/

8FILE*wf;intn.1;doubles;

ww

9rf?fopen(in.datf;

HwH

10wf?fopen(^out.datrw);

11for(i?0;i<10;(

12fscanf(rf,6n);

13s?fun(n);

M

14fprintf(wfr%lf\n"rs);

15)

16fclose(rf);fclose(wf);

17”

18?main()

i

19i(intn;doubles;

20printf("Xnlnputn:“);scanf(?%(!,?,

&n);

21s?fun(n);

w

22printC\nfa);

23NONO();

24

參考答案

1.1351\r\n3\r\n5解析:本題考查了for循環(huán)語句的使用,break語句用

在本題中是結束for循環(huán)直接跳出循環(huán)體外。當i=l時,因為if語句條

件不滿足,所以直接執(zhí)行printf(%d\\n[i++);輸出1,同時i自加1;

執(zhí)行第二次for循環(huán)時,i=3;同樣的if語句條件不滿足,所以直接執(zhí)行

printf('%d\\n',i++);輸出3,同時i自加1;執(zhí)行第三次for循環(huán)時,i=

5,if語句條件滿足,所以執(zhí)行printf(%d\\n:i),輸出5,然后break語

句跳出了for循環(huán)。

2.對象對象解析:類描述的是具有相似性質的一組對象。例如,每本具

體的書是一個對象,而這些具體的書都有共同的性質,它們都屬于更一

般的概念“書”這一類對象。一個具體對象稱為類的實例。

3.67G67G解析:根據題意,a='A'+'5'-'3'=65+2=67,b=67+4=71,71

即為字母G的ASCII碼值。程序要求按十進制形式輸出a,按字符形式

輸出b,所以結果為67G。

4.2929解析:本題考查while循環(huán)和++運算,x=27符合循環(huán)條件,執(zhí)

行循環(huán)體中x++后,x=28,if條件也成立,執(zhí)行x++后退出,x的值增

1,結果x=29。

5.r+b[k]*x

6.40

40解析:本題中指針si和s2都指向同一個內存中的地址。因此語句

“*s2=20;”執(zhí)行后,*\u3000sl=*s2=20o所以m最后的值為40。

7.n/2性表的任何位置插入一個元素的概率相等,即概率為p=l/(n+l),

則插入一個元素時所需移動元素的平均次數為E=l/(n+l)(n-i+l)=

n/2o

8.str[i]str[i+1]"%s"strstr[i]\r\nstr[i+1]\r\n'%s',str解析:本題要求將字符串

str中的字符用冒泡排序算法從大到小排列,其實過程是將相鄰兩個字

符進行比較,如果當前字符小于下一個字符,則通過中間變量temp將

字符兩兩交換,所以第一空應填:第二空應填str[i+l]最終打印輸

出得到的字符串str,所以第三空應填%s;str。

9.過程過程

10.-24-24解析:本題考查賦值運算符a+=b等價于a=a+b;a-=a*a等價

于a=a-a*a=4-4*4=-12;a+=a,艮[1a=a+a=-24o

ll.A

12.D解析:本題考查語句的基本構成。選項A)中j=5后面少了一個分

號:選項B)中少了“}”;選項C)不是一個完整的函數定義格式,一個完

整的函數定義格式還包括一對花括號:選項D)正確,是一個空語句。

13.D

14.B

15.A

16.AAO【解析】線性表的存儲通常分為兩種存儲結構:順序存儲結構和

鏈式存儲結構。

\n

17.B

解析:模塊獨立性是指每個模塊只完成系統(tǒng)要求的獨立的子功能,并

且與其他模塊的聯系最少且接口簡單。耦合性與內聚性是模塊獨立性

的兩個定性標準,耦合與內聚是相互關聯的。在程序結構中,各模塊

的內聚性越強,則耦合性越弱。一般較優(yōu)秀的軟件設計,應盡量做到

高內聚,低耦合,即減弱模塊之間的耦合性和提高模塊內的內聚性,

有利于提高模塊的獨立性。本題答案為B。

18.A“*P[3『是一個字符,也就是str[3][0],不是字符串,選項A錯誤。

“P[3『"str[27和“*p”分別代表了ddd、ccc、aaao故本題答案為A選項。

19.D

20.C

21.

【解析】要刪除字符串尾部的所有*,只要將尾部所有*中的第一個改為

字符串結束符即可。首先,將字符串指針移動到字符串最后一個位置,

檢查最后一個字符,是*則將指針前移,否則將指針后移一個位置賦值

作為結束符。

22.

【解析】題目要求寫出程序實現數學表達式的功能,需要用for循環(huán)計

算累加的結果,調用sqrt函數實現求平方根。循環(huán)變量的范圍是1?

m,每次循環(huán)都進行一次累加求和。需要特別注意的是,log函數的形

式參數為double型變量,用于循環(huán)的計數變量為整數,所以必須強制

轉換。最后返回所求出的平方根。

23.\r\n\tvoidproc(int(*s)[10],int*b,int*n,intmm,intnn)

(

inti,j,k=0;

for(i=0;i<mm;i++)//i是表示其行的下標

for(j=0;j<nn;j++)//j是表示其列的下標

b[k++]=s[i][j];//把其放到b的一維數組中

*n=k;//把b數組的長度通過形參n傳回到主函數中

【解析】要將M行N列的二維數組中的數據,按行的順序依次放到一

維數組中,可以通過首先行循環(huán),然后列循環(huán)取出二維數組中的每一

個元素,并將其放入一維數組中。最后,將一維數組的長度通過形參

返回到主函數當中。

24.

【解析】由函數proc()可知,數組PP中存放26個字母各自出現的次數,

初始化為0。然后判斷字符串比中每一個字符,每檢查一個字符,將數

組PP中相應的元素加lo

25.

【解析】要求出二維數組中最大元素的值,需要比較二維數組中每一個

元素的值。首先,定義變量max用來存放最大元素的值,將其初始化為

二維數組中第一個元素的值。然后將其與后面的每一個元素進行比較,

將二維數組中最大元素的值放到變量max當中,并將其返回給主函數。

26.ldoublefun(doublex,intn)

2{

3inti;

4doubles=l.0,sl=l.0;

5for(i=l/i<=n;i++)

6{si=si*i;/*各項中的階乘*/?s=s+pow(x,i)/si;/*按公式求出*/}Returns;10)

程序定義了變量S1和s,si表示每項的分母(即各項的階乘),S存放累

加和。循環(huán)語句控制累加的次數,在循環(huán)體中進行階乘和累加操作,

將累加的結果存入S中。此處使用了求乘方函數pow(X,i),其含義是

求X的i次方的值。

27.

【解析】在while循環(huán)中,利用if判斷表達式中每一個字符是否為

如果不是,將其復制到字符串,否則跳過,這就實現了函數的功能。

⑴首先利用工作指針指向字符串,當指針不指向串尾時,就對字符串進

行循環(huán)判斷。

(2)在循環(huán)中利用if判斷表達式字符是否為“#",如果不是,將其復制到

字符串,否則跳過。

(3)所有字符處理完后,記得在新串s的末尾加上結束符“‘\0'"。

28.

【解析】字符串數組中每一行都是一個完整的字符串,其結束標志為‘

\0'。因此,通過字符串的結束標志來判斷每一個字符串是否結束,將

字符串數組中的所有字符串均賦值給新的一維數組b來完成字符串的

合并。

29.doublefun(STREC*a,STREC*b,int*n)

inti,j=0;

doubleav=0.0;

for(i=0;i<=""p="">

av=av+a[i].s;

av=av/N;/*求平均分*/

for(i=0;i<=""p="">

if(a[i].s<av)<p=""x/av)<>

b[j++]=a[i];

/*將低于平均分的學生記錄存入結構體數組b中*/

*n=j;

/*傳回低于平均分的學生人數*/

returnav;

/*返回平均分*/

)

本題使用循環(huán)語句和條件判斷語句來實現題目要求。第1個循環(huán)語句的

作用是求出總分,然后求出平均分av。第2個循環(huán)語句的作用是將分數

低于平均分的學生記錄存入結構體數組b中。

30.voidfun(char*a)

(

inti,j=0;

for(i=0;a[i]!='\O,;i++)

!=、*,)

a[j++]=a[i];

/*若不是要刪除的字符'*'則保留*/

a[j]='\0';

/*最后加上字符串結束標志、(T*/

)

該題考核的是刪除字符串中所有*,需用循環(huán)語句遍歷字符串,用判斷

語句判斷字符是否為*,由此可以決定該程序應使用循環(huán)判斷結構。

用循環(huán)操作從字符串開始向后逐個進行比較,若不是要刪除的字符(用

if(a[i]!=+)來控制)則保留。變量i和j用來表示原字符串的下標和刪除

*后新字符串的下標。注意,下標變量j要從0開始,最后還要加上字

符串結束標志,\\0\

31.(l)for(i=1;i<=y;i++)(2)t=t%1000;

(l)for(i=l;i<=y;i++)(2)t=t%1000;解析:本題中函數的功能是

求整數x的y次方的低3位值。本題解題過程首先是求y次方,然后

對結果進行截取。

32.(1)錯誤:while(x[i]==O)正確:while(x[i]!=O)(2)錯誤:sum=sum\c;

正確:sum=sum/c;(l)錯誤:while(x[i]==O)正確:while(x[i]!=0)\r\n(2)錯

誤:sum=sum\\c;正確:sum=sum/c;解析:錯誤1:此處考查的是對循

環(huán)條件的理解,當被判斷的數組元素為。時,說明這是數組的最后一個

元素,此時要跳出循環(huán)。錯誤2:C語言中的除法運算符是7",而不是

“,,

、O

33.(l)intfun(intaintbintc)(2)elsereturn1;

(l)intfun(inta,intb,intc)(2)elsereturn1;解析:本題中函數的功能

是判斷能否構成三角形;構成的是等邊三角形,還是等腰三角形,利

用if語句判斷三邊值之間的關系,然后根據判斷結果,返回題干中要

求的值。

構成三角形的條件是任意兩邊之和大于第三邊,等腰三角形的條件是

在構成三角形的基礎上還需要兩條邊相等,等邊三角形是三條邊均相

等。

34.(1)fun(

溫馨提示

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

評論

0/150

提交評論