版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
2021年河南省商丘市全國(guó)計(jì)算機(jī)等級(jí)考試
C語(yǔ)言程序設(shè)計(jì)真題(含答案)
學(xué)校:班級(jí):姓名:考號(hào):
一、2.填空題(10題)
1.下列程序的輸出結(jié)果是【】。
main()
{inti;
for(i=l;i+1;i++)
{if(i>4)
{printf("%d\n",i);
break;}
printf("%d\n",i++);}}
2.在面向?qū)ο蠓椒ㄖ?,類的?shí)例稱為o
3.已知字母A的ASCII碼為65。以下程序運(yùn)行后的輸出結(jié)果是()。
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.以下程序的輸出結(jié)果是()。
#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函數(shù)的功能是:累加數(shù)組元素中的值,n為數(shù)組中元素的個(gè)
數(shù),累加的和值放入x所指的存儲(chǔ)單元中。請(qǐng)?zhí)羁铡?/p>
fun(intb[],intn,int*x)
{intk,r-0;
for(k=0,k<n;k++)r=[];
[]=r;
)
6.以下程序的輸出結(jié)果是[]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.長(zhǎng)度為n的順序存儲(chǔ)線性表中,當(dāng)在任何位置上插入一個(gè)元素概率
都相等時(shí),插入一個(gè)元素所需移動(dòng)元素的平均個(gè)數(shù)為【】。
8.下面的程序可對(duì)指定字符串中的字符串進(jìn)行從大到小排序,請(qǐng)將程序
填完整。(注:程序采用了冒泡排序法)
#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.子程序通常分為兩類:[]和函數(shù),前者是命令的抽象,后者是為了
求值。
10.若a是血型變量,且a的初值為4,則計(jì)算a+=a-=a*a表達(dá)式后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確表達(dá)式為().
A)n<=€1<=/B)(cl>=a)&&(cl<=z)
C)('a'>=cl||Cz,v=cl)D)(cl>='a')&&(cl<='z')
20)有下列程序,其中%u表示按無(wú)符號(hào)整數(shù)輸出。
main()
{unsignedintx=OxFFFF;/*x的初值為十六進(jìn)制數(shù)*/
printf("%u\n",x);
)
程序運(yùn)行后的輸出結(jié)果是().
A)-1B)65535
14.C)32767D)OxFFFF
15.用數(shù)組r存儲(chǔ)靜態(tài)鏈表,結(jié)點(diǎn)的next域指向后繼,工作指針j指向鏈
中結(jié)點(diǎn),使j沿鏈移動(dòng)的操作為0。
A.j=r[j].nextB.j=j+1C.j=j->nextD.j=r[j]->next
16.常采用的兩種存儲(chǔ)結(jié)構(gòu)是()。
A.順序存儲(chǔ)結(jié)構(gòu)和鏈?zhǔn)酱鎯?chǔ)結(jié)構(gòu)B.散列方法和索引方式C.鏈表存儲(chǔ)
結(jié)構(gòu)和數(shù)組D.線性存儲(chǔ)結(jié)構(gòu)和非線性存儲(chǔ)結(jié)構(gòu)
17.為了使模塊盡可能獨(dú)立,要求。
A.模塊的內(nèi)聚程度要盡量高,且各模塊間的耦合程度要盡量強(qiáng)
B.模塊的內(nèi)聚程度要盡量高,且各模塊間的耦合程度要盡量弱
C.模塊的內(nèi)聚程度要盡量低,且各模塊間的耦合程度要盡量弱
D.模塊的內(nèi)聚程度要盡量低,且各模塊間的耦合程度要盡量強(qiáng)
18.有以下程序段:
charstr[4][12]={“aaa”,“bbb”,“ccc”,“ddd"},*p[4];
inti;for(i=0;i<4;i++)p[i]=str[i];
以下選項(xiàng)中不能正確引用字符串的是()。
A.*p[3]B.p[3]C.str[2]D.*p
19.下列關(guān)于效率的說(shuō)法不正確的是()
A.效率是一個(gè)性能要求,其目標(biāo)應(yīng)該在需求分析時(shí)給出
B.提高程序效率的根本途徑在于選擇良好的設(shè)計(jì)方法,數(shù)據(jù)結(jié)構(gòu)與算法
C.效率主要指處理機(jī)時(shí)間和存儲(chǔ)器容量?jī)蓚€(gè)方面
D.程序的效率與程序的簡(jiǎn)單性無(wú)關(guān)
20.對(duì)長(zhǎng)度為n的無(wú)序線性表進(jìn)行順序查找,則查找成功、不成功時(shí)的平
均數(shù)據(jù)比較次數(shù)分別為()。
A.n/2,nB,n+l/2,n-lC.n+l/2,nD.n-l/2,n-l
三、程序設(shè)計(jì)題(10題)
21.假定輸入的字符串中只包含字母和*號(hào)。請(qǐng)編寫函數(shù)proc(),它的功
能是:將字符串尾部的*號(hào)全部刪除,前面和中間的*號(hào)不刪除。例如,
若字符串中的內(nèi)容為****a*bc*def*g。***,刪除后,字符串中的內(nèi)容則
應(yīng)當(dāng)是****a*bc*def*g。注意:部分源程序給出如下。請(qǐng)勿改動(dòng)主函
數(shù)main和其他函數(shù)中的任何內(nèi)容,僅在函數(shù)proc的花括號(hào)中填入所編
寫的若干語(yǔ)句。試題程序:
£tnciudch>
votdpraHchdif?*tr>
voidnuun?>
HuirJi
prmtfC'FnuraMnngt\na)?
proc(t
pnntf<7而.afterdeletedi\n")t
22.編寫函數(shù)fun(),其功能是計(jì)算:
S作為函數(shù)值返回。
在C語(yǔ)言中可調(diào)用log(n)函數(shù)求ln(n)olog函數(shù)的引
用說(shuō)明為:doublelog(doublex)。
例如,若m的值為20,則fun()函數(shù)值為6.506583。
注意:部分源程序給出如下。
請(qǐng)勿改動(dòng)main()函數(shù)和其他函數(shù)中的任何內(nèi)容,僅在函數(shù)fun()的花括
號(hào)中填入你編寫的若干語(yǔ)句。
試題程序:
9mcludcVadhhh>
gincludeVcons0t
9include
9tncludrVath.bA
lioublelun<mltB>
raidmain()
("CLS")i
prifith(\nM?fun<20)):
23.請(qǐng)編寫函數(shù)proc,該函數(shù)的功能是:將M行N列的二維數(shù)組中的
數(shù)據(jù),按行的順序依次放到一維數(shù)組中,一維數(shù)組中數(shù)據(jù)的個(gè)數(shù)存放
在形參n所指的存儲(chǔ)單元中。
例如,若二維數(shù)組中的數(shù)據(jù)為
13233343
14243444
15253545
則一維數(shù)組中的內(nèi)容應(yīng)該是132333431424344415253545。
注意:部分源程序給出如下。
請(qǐng)勿改動(dòng)main函數(shù)和其他函數(shù)中的任何內(nèi)容,僅在函數(shù)proc的花括
號(hào)中填入所編寫的若干語(yǔ)句。
試題程序:
#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.請(qǐng)編寫一"函數(shù)voidproc(char*tt,intpp[]),統(tǒng)計(jì)在tt字符串中“a”
到“z”26個(gè)字母各自出現(xiàn)的次數(shù),并依次放在pp所指數(shù)組中。例如,
當(dāng)輸入字符串a(chǎn)bcdefghxyzabcde"e后,程序的輸出結(jié)果應(yīng)該是:
222233110000000000000000111o注意:部分源程序給出如下。請(qǐng)勿改
動(dòng)main()函數(shù)和其他函數(shù)中的任何內(nèi)容,僅在函數(shù)proc()的花括號(hào)
中填入所編寫的若干語(yǔ)句。試題程序:
/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.
請(qǐng)編寫一個(gè)函數(shù)proc(),它的功能是:求出一個(gè)4xN整型二維數(shù)組中
最大元素的值,并將此值返回調(diào)用函數(shù)。注意:部分源程序給出如下。
請(qǐng)勿改動(dòng)main()函數(shù)和其他函數(shù)中的任何內(nèi)容,僅在函數(shù)proc的花
括號(hào)中填入所編寫的若干語(yǔ)句。試題程序:
=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中的解決方案。此解決
方案的項(xiàng)目中包含一個(gè)源程序文件progl.c。在此程序中,請(qǐng)編寫函數(shù)
fun(),它的功能是計(jì)算下列級(jí)數(shù)和,和值由函數(shù)值返回。
23M
S=1?X+工+<+.??+工
,■2!3!”!例如,當(dāng)n=10,x=0.3時(shí),函數(shù)值為
1.349859。注意:部分源程序在文件progl.c中。請(qǐng)勿改動(dòng)主函數(shù)
main()和其他函數(shù)中的任何內(nèi)容,僅在函數(shù)fun()的花括號(hào)中填入你編
寫的若干語(yǔ)句。試題程序:
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.
假定輸入的字符串只包含字母和“#”號(hào),請(qǐng)編寫函數(shù)fun(),它的功能
是:刪除字符串中所有的“#”號(hào)。在編寫函數(shù)時(shí),不得使用C語(yǔ)言提供
的字符串函數(shù)。例如,若字符串中的內(nèi)容為“##w#el##come###",刪除
后,字符串中的內(nèi)容則應(yīng)當(dāng)是“welcome”。請(qǐng)勿改動(dòng)main()函數(shù)與其
他函數(shù)中的任何內(nèi)容,僅在函數(shù)fun()的花括號(hào)中填入所編寫的若干
語(yǔ)句。試題程序:
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.
請(qǐng)編寫函數(shù)proc(),該函數(shù)的功能是:將放在字符串?dāng)?shù)組中的M個(gè)字
符串(每串的長(zhǎng)度不超過(guò)N).按順序合并組成一個(gè)新的字符串。例如,
若字符串?dāng)?shù)組中的M個(gè)字符串為:ABCDBCDEFGCDEFGHI則合并
后的字符串內(nèi)容應(yīng)該是:ABCDBCDEFGCDEFGH1o注意:部分源程
序給出如下。請(qǐng)勿改動(dòng)main()函數(shù)和其他函數(shù)中的任何內(nèi)容,僅在
函數(shù)proc()的花括號(hào)中填入所編寫的若干語(yǔ)句。試題程序:
*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中的解決方案。此解決方
案的項(xiàng)目中包含一個(gè)源程序文件progl.c。在此程序中,學(xué)生的記錄由學(xué)
號(hào)和成績(jī)組成,N名學(xué)生的記錄已在主函數(shù)中放入結(jié)構(gòu)體數(shù)組s中,請(qǐng)
編寫函數(shù)fun(),其功能是把低于平均分的學(xué)生記錄放入b所指的數(shù)組
中,低于平均分的學(xué)生人數(shù)通過(guò)形參n返回,平均分通過(guò)函數(shù)值返回。
注意:部分源程序給出如下。
請(qǐng)勿改動(dòng)主函數(shù)main()和其他函數(shù)中的任何內(nèi)容,僅在函數(shù)fun()的花
括號(hào)中填入你編寫的若干語(yǔ)句。
試題程序:
#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++)<>
/*輸出成績(jī)低于平均分的學(xué)生記錄*/
printf("%s%4.1f\n^^,h[i].num,h[i].s);
printf
30.使用VC++2010打開考生文件夾下progl中的解決方案。此解決方
案的項(xiàng)目中包含一個(gè)源程序文件progl.c。在此程序中,規(guī)定輸入的字符
串中只包含字母和*號(hào)。編寫函數(shù)fun(),其功能是刪除字符串中所有的
*號(hào)。編寫函數(shù)時(shí),不得使用C語(yǔ)言提供的字符串函數(shù)。
例如,字符串中的內(nèi)容為“****A*BC*DEF*G*******”,刪除后,字符
串中的內(nèi)容應(yīng)當(dāng)是“ABCDEFG”。
注意:部分源程序給出如下。
請(qǐng)勿改動(dòng)主函數(shù)main()和其他函數(shù)中的任何內(nèi)容,僅在函數(shù)fun()的花
括號(hào)中填入你編寫的若干語(yǔ)句。
試題程序:
#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中函數(shù)fun的功能是:求整數(shù)x的y次方的低
3位值。例如,整數(shù)5的6次方為15625,此值的低3位值為625。
請(qǐng)改正函數(shù)fun中指定部位的錯(cuò)誤,使它能得出正確的結(jié)果。
注意:不要改動(dòng)main函數(shù),不得增行或刪行,也不得更改程序的結(jié)構(gòu)!
;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.在主函數(shù)中從鍵盤輸入若干個(gè)數(shù)放入數(shù)組中,用。結(jié)束輸入并放在
最后一個(gè)元素中。下列給定程序中,函數(shù)fun()的功能是計(jì)算數(shù)組元素中
值為負(fù)數(shù)的平均值(不包括0)。
例如:數(shù)組中元素的值依次為43,47,-21,53,-8,12,0,則程序的
運(yùn)行結(jié)果為-25.333333。
請(qǐng)改正程序中的錯(cuò)誤,使它能得到正確結(jié)果。
注意:不要改動(dòng)main函數(shù),不得增行或刪行,也不得更改程序的結(jié)構(gòu)。
試題程序:
#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中函數(shù)fun的功能是:根據(jù)輸入的三個(gè)邊長(zhǎng)(整
型值),判斷能否構(gòu)成三角形:構(gòu)成的是等邊三角形,還是等腰三角形。
若能構(gòu)成等邊三角形函數(shù)返回3,若能構(gòu)成等腰三角形函數(shù)返回2,若
能構(gòu)成一般三角形函數(shù)返回1,若不能構(gòu)成三角形函數(shù)返回0。
請(qǐng)改正函數(shù)fun中指定部位的錯(cuò)誤,使它能得出正確的結(jié)果。
注意:不要改動(dòng)main函數(shù),不得增行或刪行,也不得更改程序的結(jié)構(gòu)!
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.下列給定程序中,函數(shù)fun()的功能是:從N個(gè)字符串中找出最長(zhǎng)的
那個(gè)中,并將其地址作為函數(shù)值返回。各字符串在主函數(shù)中輸入,并放
入一個(gè)字符串?dāng)?shù)組中。
請(qǐng)改正程序中的錯(cuò)誤,使它能得出正確的結(jié)果。
注意:不要改動(dòng)main函數(shù),不得增行或刪行,也不得更改程序的結(jié)構(gòu)。
試題程序:
#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.下列給定程序中,函數(shù)fun()的功能是:統(tǒng)計(jì)字符串substr在字符串
srt中出現(xiàn)的次數(shù)。例如,若字符串為aaas1kaaas,子字符串為as,則
應(yīng)輸出2。
請(qǐng)改正程序中的錯(cuò)誤,使它能得出正確的結(jié)果。
注意:不要改動(dòng)main函數(shù),不得增行或刪行,也不得更改程序的結(jié)構(gòu)。
試題程序:
#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.下列給定程序中,函數(shù)fun()的功能是找出100?n(n不大于1000)之
間百位數(shù)字加十位數(shù)字等于個(gè)位數(shù)字的所有整數(shù),把這些整數(shù)放在s所
指的數(shù)組中,個(gè)數(shù)作為函數(shù)值返回。
請(qǐng)改正程序中的錯(cuò)誤,使它能得到正確結(jié)果。
注意:不要改動(dòng)main函數(shù),不得增行或刪行,也不得更改程序的結(jié)構(gòu)。
試題程序:
#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中函數(shù)fun的功能是:計(jì)算n的5次方的值(規(guī)
定n的值大于2、小于8),通過(guò)形參指針傳回主函數(shù);并計(jì)算該值的個(gè)
位、十位、百位上數(shù)字之和作為函數(shù)值返回。
例如,7的5次方是16807,其低3位數(shù)的和值是15。
請(qǐng)改正函數(shù)fun中指定部位的錯(cuò)誤,使它能得出正確的結(jié)果。
注意:不要改動(dòng)main函數(shù),不得增行或刪行,也不得更改程序的結(jié)構(gòu)!
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中函數(shù)fun的功能是:從整數(shù)1到55之間,選
出能被3整除、且有一位上的數(shù)是5的那些數(shù),并把這些數(shù)放在b所指
的數(shù)組中,這些數(shù)的個(gè)數(shù)作為函數(shù)值返回。規(guī)定,函數(shù)中al放個(gè)位數(shù),
a2放十位數(shù)。
請(qǐng)改正程序中的錯(cuò)誤,使它能得出正確結(jié)果。
注意:不要改動(dòng)main函數(shù),不得增行或刪行,也不得更改程序的結(jié)構(gòu)。
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中函數(shù)fun的功能是:判斷一個(gè)整數(shù)是否是素
數(shù),若是返回1,否則返回0。
在mai()函數(shù)中,若fun返回1輸出YES,若fun返回。輸出NO!。
請(qǐng)改正程序中的錯(cuò)誤,使它能得出正確的結(jié)果。
注意:不要改動(dòng)main函數(shù)。不得增行或刪行,也不得更改程序的結(jié)構(gòu)!
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.下列給定程序中,函數(shù)fun()的功能是:在字符串str中找出ASCII
碼值最大的字符,將其放在第一個(gè)位置上,并將該字符前的原字符向后
順序移動(dòng)。例如,調(diào)用fun()函數(shù)之前給字符串輸入ABCDeFGH,調(diào)用
后字符串中的內(nèi)容為eABCDFGHo
請(qǐng)改正程序中的錯(cuò)誤,使它能得出正確的結(jié)果。
注意:不要改動(dòng)main函數(shù),不得增行或刪行,也不得更改程序的結(jié)構(gòu)。
試題程序:
#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");
五、程序改錯(cuò)題(2題)
41.下列給定程序中函數(shù)fun的功能是:將■所指字符串中的小寫字母全
部改為對(duì)應(yīng)的大寫字母,其他字符不變。
例如,若輸入“Ab,cD",則輸出“AB,CD”。
請(qǐng)改正程序中的錯(cuò)誤,使它能得出正確的結(jié)果。
注意:部分源程序在文件M0DI1.C中,不得增行或刪行,也不得更改
程序的結(jié)構(gòu)!
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.
下列給定程序中,函數(shù)proc()的功能是:計(jì)算并輸出下列級(jí)數(shù)的前N
項(xiàng)之和SN,直到SN+1大于q為止。q的值通過(guò)形參傳人。SN=2/1+3
/2+4/3+(N+l)/N例如,若q的值為57,則函數(shù)值為59.593612。
請(qǐng)修改程序中的錯(cuò)誤,使它能得出正確的結(jié)果。注意:不要改動(dòng)main
()函數(shù),不得增行或刪行,也不得更改程序的結(jié)構(gòu)。試題程序:
: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.給定程序中,函數(shù)fun的功能是:調(diào)用隨機(jī)函數(shù)產(chǎn)生20個(gè)互不相同
的整數(shù)放在形參a所指數(shù)組中(此數(shù)組在主函數(shù)中已置0)。
請(qǐng)?jiān)诔绦虻南聞澗€處填入正確的內(nèi)容并把下劃線刪除,使程序得出正確
的結(jié)果。
注意:源程序存放在考生文件夾下的BLANK1.C中。
不得增行或刪行,也不得更改程序的結(jié)構(gòu)!
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.請(qǐng)編寫函數(shù)fun,它的功能是:計(jì)算并輸出n(包括n)以內(nèi)能被5或9
整除的所有自然數(shù)的倒數(shù)之和。
例如,在主函數(shù)中從鍵盤給n輸入20后,輸出為:s=0.583333o注
意:要求n的值不大于100o
部分源程序在文件PROGLC中。
請(qǐng)勿改動(dòng)主函數(shù)main和其他函數(shù)中的任何內(nèi)容,僅在函數(shù)fun的花括
號(hào)中填入你編寫的若干語(yǔ)句。
1:linclude<stdio.h>
2doublefun(intn)
3
4
5
6NONO()
7(/?請(qǐng)?jiān)诖撕瘮?shù)內(nèi)打開文件,輸入測(cè)試數(shù)據(jù).
調(diào)用fun函畋,轆出數(shù)據(jù).關(guān)閉文件.?/
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)語(yǔ)句的使用,break語(yǔ)句用
在本題中是結(jié)束for循環(huán)直接跳出循環(huán)體外。當(dāng)i=l時(shí),因?yàn)閕f語(yǔ)句條
件不滿足,所以直接執(zhí)行printf(%d\\n[i++);輸出1,同時(shí)i自加1;
執(zhí)行第二次for循環(huán)時(shí),i=3;同樣的if語(yǔ)句條件不滿足,所以直接執(zhí)行
printf('%d\\n',i++);輸出3,同時(shí)i自加1;執(zhí)行第三次for循環(huán)時(shí),i=
5,if語(yǔ)句條件滿足,所以執(zhí)行printf(%d\\n:i),輸出5,然后break語(yǔ)
句跳出了for循環(huán)。
2.對(duì)象對(duì)象解析:類描述的是具有相似性質(zhì)的一組對(duì)象。例如,每本具
體的書是一個(gè)對(duì)象,而這些具體的書都有共同的性質(zhì),它們都屬于更一
般的概念“書”這一類對(duì)象。一個(gè)具體對(duì)象稱為類的實(shí)例。
3.67G67G解析:根據(jù)題意,a='A'+'5'-'3'=65+2=67,b=67+4=71,71
即為字母G的ASCII碼值。程序要求按十進(jìn)制形式輸出a,按字符形式
輸出b,所以結(jié)果為67G。
4.2929解析:本題考查while循環(huán)和++運(yùn)算,x=27符合循環(huán)條件,執(zhí)
行循環(huán)體中x++后,x=28,if條件也成立,執(zhí)行x++后退出,x的值增
1,結(jié)果x=29。
5.r+b[k]*x
6.40
40解析:本題中指針si和s2都指向同一個(gè)內(nèi)存中的地址。因此語(yǔ)句
“*s2=20;”執(zhí)行后,*\u3000sl=*s2=20o所以m最后的值為40。
7.n/2性表的任何位置插入一個(gè)元素的概率相等,即概率為p=l/(n+l),
則插入一個(gè)元素時(shí)所需移動(dòng)元素的平均次數(shù)為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中的字符用冒泡排序算法從大到小排列,其實(shí)過(guò)程是將相鄰兩個(gè)字
符進(jìn)行比較,如果當(dāng)前字符小于下一個(gè)字符,則通過(guò)中間變量temp將
字符兩兩交換,所以第一空應(yīng)填:第二空應(yīng)填str[i+l]最終打印輸
出得到的字符串str,所以第三空應(yīng)填%s;str。
9.過(guò)程過(guò)程
10.-24-24解析:本題考查賦值運(yùn)算符a+=b等價(jià)于a=a+b;a-=a*a等價(jià)
于a=a-a*a=4-4*4=-12;a+=a,艮[1a=a+a=-24o
ll.A
12.D解析:本題考查語(yǔ)句的基本構(gòu)成。選項(xiàng)A)中j=5后面少了一個(gè)分
號(hào):選項(xiàng)B)中少了“}”;選項(xiàng)C)不是一個(gè)完整的函數(shù)定義格式,一個(gè)完
整的函數(shù)定義格式還包括一對(duì)花括號(hào):選項(xiàng)D)正確,是一個(gè)空語(yǔ)句。
13.D
14.B
15.A
16.AAO【解析】線性表的存儲(chǔ)通常分為兩種存儲(chǔ)結(jié)構(gòu):順序存儲(chǔ)結(jié)構(gòu)和
鏈?zhǔn)酱鎯?chǔ)結(jié)構(gòu)。
\n
17.B
解析:模塊獨(dú)立性是指每個(gè)模塊只完成系統(tǒng)要求的獨(dú)立的子功能,并
且與其他模塊的聯(lián)系最少且接口簡(jiǎn)單。耦合性與內(nèi)聚性是模塊獨(dú)立性
的兩個(gè)定性標(biāo)準(zhǔn),耦合與內(nèi)聚是相互關(guān)聯(lián)的。在程序結(jié)構(gòu)中,各模塊
的內(nèi)聚性越強(qiáng),則耦合性越弱。一般較優(yōu)秀的軟件設(shè)計(jì),應(yīng)盡量做到
高內(nèi)聚,低耦合,即減弱模塊之間的耦合性和提高模塊內(nèi)的內(nèi)聚性,
有利于提高模塊的獨(dú)立性。本題答案為B。
18.A“*P[3『是一個(gè)字符,也就是str[3][0],不是字符串,選項(xiàng)A錯(cuò)誤。
“P[3『"str[27和“*p”分別代表了ddd、ccc、aaao故本題答案為A選項(xiàng)。
19.D
20.C
21.
【解析】要?jiǎng)h除字符串尾部的所有*,只要將尾部所有*中的第一個(gè)改為
字符串結(jié)束符即可。首先,將字符串指針移動(dòng)到字符串最后一個(gè)位置,
檢查最后一個(gè)字符,是*則將指針前移,否則將指針后移一個(gè)位置賦值
作為結(jié)束符。
22.
【解析】題目要求寫出程序?qū)崿F(xiàn)數(shù)學(xué)表達(dá)式的功能,需要用for循環(huán)計(jì)
算累加的結(jié)果,調(diào)用sqrt函數(shù)實(shí)現(xiàn)求平方根。循環(huán)變量的范圍是1?
m,每次循環(huán)都進(jìn)行一次累加求和。需要特別注意的是,log函數(shù)的形
式參數(shù)為double型變量,用于循環(huán)的計(jì)數(shù)變量為整數(shù),所以必須強(qiáng)制
轉(zhuǎ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是表示其行的下標(biāo)
for(j=0;j<nn;j++)//j是表示其列的下標(biāo)
b[k++]=s[i][j];//把其放到b的一維數(shù)組中
*n=k;//把b數(shù)組的長(zhǎng)度通過(guò)形參n傳回到主函數(shù)中
【解析】要將M行N列的二維數(shù)組中的數(shù)據(jù),按行的順序依次放到一
維數(shù)組中,可以通過(guò)首先行循環(huán),然后列循環(huán)取出二維數(shù)組中的每一
個(gè)元素,并將其放入一維數(shù)組中。最后,將一維數(shù)組的長(zhǎng)度通過(guò)形參
返回到主函數(shù)當(dāng)中。
24.
【解析】由函數(shù)proc()可知,數(shù)組PP中存放26個(gè)字母各自出現(xiàn)的次數(shù),
初始化為0。然后判斷字符串比中每一個(gè)字符,每檢查一個(gè)字符,將數(shù)
組PP中相應(yīng)的元素加lo
25.
【解析】要求出二維數(shù)組中最大元素的值,需要比較二維數(shù)組中每一個(gè)
元素的值。首先,定義變量max用來(lái)存放最大元素的值,將其初始化為
二維數(shù)組中第一個(gè)元素的值。然后將其與后面的每一個(gè)元素進(jìn)行比較,
將二維數(shù)組中最大元素的值放到變量max當(dāng)中,并將其返回給主函數(shù)。
26.ldoublefun(doublex,intn)
2{
3inti;
4doubles=l.0,sl=l.0;
5for(i=l/i<=n;i++)
6{si=si*i;/*各項(xiàng)中的階乘*/?s=s+pow(x,i)/si;/*按公式求出*/}Returns;10)
程序定義了變量S1和s,si表示每項(xiàng)的分母(即各項(xiàng)的階乘),S存放累
加和。循環(huán)語(yǔ)句控制累加的次數(shù),在循環(huán)體中進(jìn)行階乘和累加操作,
將累加的結(jié)果存入S中。此處使用了求乘方函數(shù)pow(X,i),其含義是
求X的i次方的值。
27.
【解析】在while循環(huán)中,利用if判斷表達(dá)式中每一個(gè)字符是否為
如果不是,將其復(fù)制到字符串,否則跳過(guò),這就實(shí)現(xiàn)了函數(shù)的功能。
⑴首先利用工作指針指向字符串,當(dāng)指針不指向串尾時(shí),就對(duì)字符串進(jìn)
行循環(huán)判斷。
(2)在循環(huán)中利用if判斷表達(dá)式字符是否為“#",如果不是,將其復(fù)制到
字符串,否則跳過(guò)。
(3)所有字符處理完后,記得在新串s的末尾加上結(jié)束符“‘\0'"。
28.
【解析】字符串?dāng)?shù)組中每一行都是一個(gè)完整的字符串,其結(jié)束標(biāo)志為‘
\0'。因此,通過(guò)字符串的結(jié)束標(biāo)志來(lái)判斷每一個(gè)字符串是否結(jié)束,將
字符串?dāng)?shù)組中的所有字符串均賦值給新的一維數(shù)組b來(lái)完成字符串的
合并。
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];
/*將低于平均分的學(xué)生記錄存入結(jié)構(gòu)體數(shù)組b中*/
*n=j;
/*傳回低于平均分的學(xué)生人數(shù)*/
returnav;
/*返回平均分*/
)
本題使用循環(huán)語(yǔ)句和條件判斷語(yǔ)句來(lái)實(shí)現(xiàn)題目要求。第1個(gè)循環(huán)語(yǔ)句的
作用是求出總分,然后求出平均分av。第2個(gè)循環(huán)語(yǔ)句的作用是將分?jǐn)?shù)
低于平均分的學(xué)生記錄存入結(jié)構(gòu)體數(shù)組b中。
30.voidfun(char*a)
(
inti,j=0;
for(i=0;a[i]!='\O,;i++)
!=、*,)
a[j++]=a[i];
/*若不是要?jiǎng)h除的字符'*'則保留*/
a[j]='\0';
/*最后加上字符串結(jié)束標(biāo)志、(T*/
)
該題考核的是刪除字符串中所有*,需用循環(huán)語(yǔ)句遍歷字符串,用判斷
語(yǔ)句判斷字符是否為*,由此可以決定該程序應(yīng)使用循環(huán)判斷結(jié)構(gòu)。
用循環(huán)操作從字符串開始向后逐個(gè)進(jìn)行比較,若不是要?jiǎng)h除的字符(用
if(a[i]!=+)來(lái)控制)則保留。變量i和j用來(lái)表示原字符串的下標(biāo)和刪除
*后新字符串的下標(biāo)。注意,下標(biāo)變量j要從0開始,最后還要加上字
符串結(jié)束標(biāo)志,\\0\
31.(l)for(i=1;i<=y;i++)(2)t=t%1000;
(l)for(i=l;i<=y;i++)(2)t=t%1000;解析:本題中函數(shù)的功能是
求整數(shù)x的y次方的低3位值。本題解題過(guò)程首先是求y次方,然后
對(duì)結(jié)果進(jìn)行截取。
32.(1)錯(cuò)誤:while(x[i]==O)正確:while(x[i]!=O)(2)錯(cuò)誤:sum=sum\c;
正確:sum=sum/c;(l)錯(cuò)誤:while(x[i]==O)正確:while(x[i]!=0)\r\n(2)錯(cuò)
誤:sum=sum\\c;正確:sum=sum/c;解析:錯(cuò)誤1:此處考查的是對(duì)循
環(huán)條件的理解,當(dāng)被判斷的數(shù)組元素為。時(shí),說(shuō)明這是數(shù)組的最后一個(gè)
元素,此時(shí)要跳出循環(huán)。錯(cuò)誤2:C語(yǔ)言中的除法運(yùn)算符是7",而不是
“,,
、O
33.(l)intfun(intaintbintc)(2)elsereturn1;
(l)intfun(inta,intb,intc)(2)elsereturn1;解析:本題中函數(shù)的功能
是判斷能否構(gòu)成三角形;構(gòu)成的是等邊三角形,還是等腰三角形,利
用if語(yǔ)句判斷三邊值之間的關(guān)系,然后根據(jù)判斷結(jié)果,返回題干中要
求的值。
構(gòu)成三角形的條件是任意兩邊之和大于第三邊,等腰三角形的條件是
在構(gòu)成三角形的基礎(chǔ)上還需要兩條邊相等,等邊三角形是三條邊均相
等。
34.(1)fun(
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2024年文化中心停車場(chǎng)場(chǎng)地租賃使用合同3篇
- 2024版公司船員合同期內(nèi)請(qǐng)休假管理規(guī)定
- 2024水果銷售合同
- 2024版單位臨時(shí)工聘用合同
- 2024年砌墻工程設(shè)備租賃與維護(hù)合同
- 南京郵電大學(xué)《程序設(shè)計(jì)語(yǔ)言B》2023-2024學(xué)年第一學(xué)期期末試卷
- 江西省上饒市2024年中考數(shù)學(xué)二模試題含答案
- 九江職業(yè)大學(xué)《商業(yè)推廣設(shè)計(jì)》2023-2024學(xué)年第一學(xué)期期末試卷
- 江蘇航空職業(yè)技術(shù)學(xué)院《Premere視頻編輯應(yīng)用與實(shí)踐》2023-2024學(xué)年第一學(xué)期期末試卷
- 黃淮學(xué)院《舞蹈編創(chuàng)(一)》2023-2024學(xué)年第一學(xué)期期末試卷
- 2025寒假散學(xué)典禮(休業(yè)式)上校長(zhǎng)精彩講話:以董宇輝的創(chuàng)新、羅振宇的堅(jiān)持、馬龍的熱愛(ài)啟迪未來(lái)
- 2025年浙江中外運(yùn)有限公司招聘筆試參考題庫(kù)含答案解析
- 建筑公司2025年度工作總結(jié)和2025年工作安排計(jì)劃
- 電壓損失計(jì)算表
- 福建省福州市2023-2024學(xué)年高二上學(xué)期期末測(cè)試英語(yǔ)試卷(含答案)
- 腦疝病人的觀察與護(hù)理
- 人民醫(yī)院建設(shè)項(xiàng)目背景分析
- 初級(jí)會(huì)計(jì)實(shí)務(wù)題庫(kù)(613道)
- 2024年高考地理時(shí)事熱點(diǎn):環(huán)保(附答案解析)
- 招標(biāo)代理機(jī)構(gòu)選取技術(shù)標(biāo)投標(biāo)方案(技術(shù)方案)
- 北師大版本八年級(jí)上冊(cè)第一章單元測(cè)試卷(A卷)【含答案】
評(píng)論
0/150
提交評(píng)論