全國計(jì)算機(jī)等級(jí)考試二級(jí)C語言筆試試題及答案6套_第1頁
全國計(jì)算機(jī)等級(jí)考試二級(jí)C語言筆試試題及答案6套_第2頁
全國計(jì)算機(jī)等級(jí)考試二級(jí)C語言筆試試題及答案6套_第3頁
全國計(jì)算機(jī)等級(jí)考試二級(jí)C語言筆試試題及答案6套_第4頁
全國計(jì)算機(jī)等級(jí)考試二級(jí)C語言筆試試題及答案6套_第5頁
已閱讀5頁,還剩66頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡(jiǎn)介

2022年3月全國計(jì)算機(jī)等級(jí)考試二級(jí)C語言筆試試題及答案(1)下列敘述中正確的是

A)棧是先進(jìn)先出(FIFO)的線性表B)隊(duì)列是先進(jìn)先出(FIFO)的線性表C)循環(huán)隊(duì)列是非線性結(jié)構(gòu)D)有序線性表既可以采用順序存儲(chǔ)結(jié)構(gòu),也可以采用鏈?zhǔn)酱鎯?chǔ)結(jié)構(gòu)(2)支持子程序調(diào)用的數(shù)據(jù)結(jié)構(gòu)是

A)棧

B)樹

C)隊(duì)列

D)二叉樹(3)某二叉樹有5個(gè)度為2的結(jié)點(diǎn),則該二叉樹中的葉子結(jié)點(diǎn)數(shù)是

A)10

B)8

C)6

D)4(4)下列排序方法中,最壞情況下比較次數(shù)最少的是

A)冒泡排序

B)簡(jiǎn)單選擇排序

C)直接插入排序

D)堆排序(5)軟件按功能可以分為:應(yīng)用軟件、系統(tǒng)軟件和支撐軟件(或工具軟件)。下面屬于應(yīng)用軟件的是

A)編譯軟件

B)操作系統(tǒng)

C)教務(wù)管理系統(tǒng)

D)匯編程序(6)下面敘述中錯(cuò)誤的是A)軟件測(cè)試的目的是發(fā)現(xiàn)錯(cuò)誤并改正錯(cuò)誤B)對(duì)被調(diào)試的程序進(jìn)行“錯(cuò)誤定位”是程序調(diào)試的必要步驟C)程序調(diào)試通常也稱為DebugD)軟件測(cè)試應(yīng)嚴(yán)格執(zhí)行測(cè)試計(jì)劃,排除測(cè)試的隨意性(7)耦合性和內(nèi)聚性是對(duì)模塊獨(dú)立性度量的兩個(gè)標(biāo)準(zhǔn)。下列敘述中正確的是A)提高耦合性降低內(nèi)聚性有利于提高模塊的獨(dú)立性B)降低耦合性提高內(nèi)聚性有利于提高模塊的獨(dú)立性C)耦合性是指一個(gè)模塊內(nèi)部各個(gè)元素間彼此結(jié)合的緊密程度D)內(nèi)聚性是指模塊間互相連接的緊密程度(8)數(shù)據(jù)庫應(yīng)用系統(tǒng)中的核心問題是A)數(shù)據(jù)庫設(shè)計(jì)

B)數(shù)據(jù)庫系統(tǒng)設(shè)計(jì)C)數(shù)據(jù)庫維護(hù)

D)數(shù)據(jù)庫管理員培訓(xùn)(9)有兩個(gè)關(guān)系R,S如下:RSABCa32b01c21ABa3b0c2

由關(guān)系R通過運(yùn)算得到關(guān)系S,則所使用的運(yùn)算為A)選擇

B)投影

C)插入

D)連接(10)將E-R圖轉(zhuǎn)換為關(guān)系模式時(shí),實(shí)體和聯(lián)系都可以表示為A)屬性

B)鍵

C)關(guān)系

D)域(11)以下選項(xiàng)中合法的標(biāo)識(shí)符是

A)1-1

B)1—1

C)-11

D)1--(12)若函數(shù)中有定義語句:intk;,則

A)系統(tǒng)將自動(dòng)給k賦初值0

B)這時(shí)k中值無定義

C)系統(tǒng)將自動(dòng)給k賦初值-1

D)這時(shí)k中無任何值(13)以下選項(xiàng)中,能用作數(shù)據(jù)常量的是

A)o115

B)0118

C)1.5e1.5

D)115L(14)設(shè)有定義:intx=2;,以下表達(dá)式中,值不為6的是A)x*=x+1

B)x++,2*x

C)x*=(1+x)

D)2*x,x+=2(15)程序段:intx=12;

doubley=3.141593;printf(“%d%8.6f”,x,y);的輸出結(jié)果是A)123.141593

B)12

3.141593

C)12,3.141593

D)123.141593(16)若有定義語句:doublex,y,*px,*py,執(zhí)行了px=&x,py=&y;之后,正確的輸入語句是

A)scanf(“%f%f”,x,y);

B)scanf(“%f%f”,&x,&y);

C)scanf(“%lf%le”,px,py);

D)scanf(“%lf%lf”,x,y);(17)以下是if語句的基本形式:if(表達(dá)式)語句,其中表達(dá)式A)必須是邏輯表達(dá)式

B)必須是關(guān)系表達(dá)式C)必須是邏輯表達(dá)式或關(guān)系表達(dá)式

D)可以是任意合法的表達(dá)式(18)有以下程序#include<stdio.h>main(){intx;scanf(“%d”,&x);if(x<=3);elseif(x!=10)

printf(“%d\n”,x);}程序運(yùn)行時(shí),輸入的值在哪個(gè)范圍才會(huì)有輸出結(jié)果A)不等于10的整數(shù)

B)大于3且不等于10的整數(shù)C)大于3或等于10的整數(shù)

D)小于3的整數(shù)(19)有以下程序#include<stdio.h>Main(){

inta=1,b=2,c=3,d=0;if(a==1&&b++==2)if(b!=2||c--!=3)

printf(“%d,%d,%d\n”,a,b,c);elseprintf(“%d,%d,%d\n”,a,b,c);elseprintf(“%d,%d,%d\n”,a,b,c);}程序運(yùn)行后的輸出結(jié)果是A)1,2,3

B)1,3,2

C)1,3,3

D)3,2,1(20)以下程序中的變量已正確定義for(i=0;i<4;i++,i++for(k=1;k<3;k++);printf(“*”);程序段的輸出結(jié)果是A)********

B)****

C)**

D)*(21)有以下程序#include<stdio.h>main(){char

*s=(“ABC);do{printf(“%d”,*s%10);s++;}while(*s);}注意,字母A的ASCII碼值為65。程序運(yùn)行后的輸出結(jié)果是A)5670

B)656667

C)567

D)ABC(22)設(shè)變量已正確定義,以下不能統(tǒng)計(jì)出一行中輸入字符個(gè)數(shù)(不包含回車符)的程序段是A)n=0;while((ch=getchar())!=’\n’)n++;

B)n=0;while(getchar()!=’\n’)n++;C)for(n=0;getchar()!=’\n’;n++);

D)n=0;for(ch=getchar();ch!=’\n’;n++);(23)有以下程序#include<stdio.h>main(){inta1,a2;charc1,c2;scanf(“%d%c%d%c”,&a1,&c1,&a2,&c2);printf(“%d,%c,%d,%c”,&1,c1,a2,c2);}若想通過鍵盤輸入,使得a1的值為12,a2的是為34,c1的值為字符a,c2的值為字符b,程序輸出結(jié)果是:12,a,34,b,則正確的輸入格式是(以下

代表空格,<CR>代表回車)A)12a34b<CR>

B)12

a

34

b<CR>C)12,a,34,b<CR>

D)12

a34

b<CR>(24)有以下程序#include<stdio.h>intf(intx,inty){return()y-x)*x);}main(){inta=3,b=4,c=5,d;d=f(f(a,b),f(a,c));printf(“%d\n”,d);}程序運(yùn)行后的輸出結(jié)果是A)10

B)9

C)8

D)7(25)有以下程序#include<stdio.h>voidfun(char

*s){while(*s)

{if(*s%2==0)

printf(“%c”,*s);s++;

}}main(){char

a[]={“good”};

fun(a);printf(“\n”);}注意:字母a的ASCII碼值為97,程序運(yùn)行后的輸出結(jié)果是A)d

B)go

C)god

D)good(26)有以下程序#include<stdio.h>voidfun(int*a,int*b){int*c;c=a;a=b;b=c;}main(){intx=3,y-5,*P=&x,*q=&y;

fun(p,q);printf(“%d,%d,”,*p,*q);fun(&x,&y);printf(“%d,%d\n”,*p,*q);}程序運(yùn)行后的輸出結(jié)果是A)3,5,5,3

B)3,5,3,5

C)5,3,3,5

D)5,3,5,3(27)有以下程序#include<stdio.h>voidf(int*p,int*q);main(){intm=1,n=2,*r=&m;

f(r,&n);printf(“%d,%d”,m,n);}voidf(int*p,int*q){p=p+1;*q=*q+1;}程序運(yùn)行后輸出的結(jié)果是A)1,3

B)2,3

C)1,4

D)1,2(28)以下函數(shù)按每行8個(gè)輸出數(shù)組中的數(shù)據(jù)voidfun(int*w,intn){inti;

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

{________

printf(“%d”,w);

}

printf(“\n”);}下劃線處應(yīng)填入的語句是A)if(i/8==0)print(“\n”);

B)if(i/8==0)continue;C)if(i%8==0)print(“\n”);

D)if(i%8==0)continue;(29)若有以下定義

intx[10],*pt=x;則對(duì)x數(shù)組元素的正確應(yīng)用是A)*&x[10]

B)*(x+3)

C)*(pt+10)

D)pt+3

(30)設(shè)有定義:chars[81];inti=10;,以下不能將一行(不超過80個(gè)字符)帶有空格的字符串真確讀入的語句或語句組是Agets(s)

B)while((s[i++]=getchar())!=”\n”;s=”\0”;C)scanf(“%s”,s);D)do{scanf(“%c”,&s);}while(s[i++]!=”\n”);s=”\0”;(31)有以下程序#include<stdio.h>main(){char*a[]={“abcd”,”ef”,”gh”,”ijk”};intI;

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

printf(“%c”,*a);}程序運(yùn)行后輸出的結(jié)果是A)aegi

B)dfhk

C)abcd

D)abcdefghijk(32)以下選項(xiàng)中正確的語句組是A)chars[];s=”BOOK!”;

B)char*s;s={”BOOK!”};C)chars[10];s=”BOOK!”;

D)char*s;s=”BOOK!”;(33)有以下程序#include<stdio.h>intfun{intx,inty}{if(x==y)return(x);

elsereturn((x+y)/2)}main(){inta=4,b=5,c=6;

printf(“%d\n”,fun(2*a,fun(b,c)))}程序運(yùn)行后的輸出結(jié)果是A)3

B)6

C)8

D)12(34)設(shè)函數(shù)中有整型變量n,為保證其在未賦值的情況下初值為0,應(yīng)選擇的存儲(chǔ)類別是A)auto

B)register

C)static

D)auto或register(35)有以下程序#include<stdio.h>intb=2;intfun(int*k){b=*k+b;return(b);}main(){inta[10]={1,2,3,4,5,6,7,8},I;

for(i=2;i<4;i++){b=fun(&a)+b;printf(“%d”,b);}

printf(“\n”);}程序運(yùn)行后輸出的結(jié)果是A)10

12

B)8

10

C)10

28

D)10

16(36)有以下程序#include<stdio.h>#definePT3.5;#defineS(x)PT*x*x;main(){inta=1,b=2;printf(“%4.1f\n”,S(a+b));}程序運(yùn)行后輸出的結(jié)果是A)14.0

B)31.5

C)7.5

D)程序有錯(cuò)無輸出結(jié)果(37)有以下程序#include<stdio.h>structord{intx,y;}dt[2]={1,2,3,4};main(){structord*p=dt;

printf(“%d,”,++p->x);printf(“%d\n”,++p->y);}程序的運(yùn)行結(jié)果是A)1,2

B)2,3

C)3,4

D)4,1(38)設(shè)有宏定義:#include

IsDIV(k,n)((k%n==1)?1:0且變量m已正確定義并賦值,則宏調(diào)用:IsDIV(m,5)&&IsDIV(m,7)為真時(shí)所要表達(dá)的是A)判斷m是否能被5或者7整除B)判斷m是否能被5和7整除C)判斷m被5或者7整除是否余1D)判斷m被5和7整除是否余1(39)有以下程序#include<stdio.h>main(){inta=5,b=1,t;

t=(a<<2|b);printf(“%d\n”,t)

}程序運(yùn)行后的輸出結(jié)果是A)21

B)11

C)6

D)1(40)有以下程序#include<stdio.h>main(){FILE*f;

f=fopen(“filea.txt”,”w”);

fprintf(f,”abc”);

fclose(f);}若文本文件filea.txt中原有內(nèi)容為:hello,則運(yùn)行以上程序后,文件filea.txt中的內(nèi)容為A)helloabc

B)abclo

C)abc

D)abchello

二、填空題(每空2分,共30分)

請(qǐng)將每一個(gè)空的正確答案寫在答題卡【1】至【15】序號(hào)的橫線上,答在試卷上不得分。(1)假設(shè)一個(gè)長(zhǎng)度為50的數(shù)組(數(shù)組元素的下標(biāo)從0到49)作為棧的存儲(chǔ)空間,棧底指針bottom指向棧底元素,棧頂指針top指向棧頂元素,如果bottom=49,top=30(數(shù)組下標(biāo)),則棧中具有【1】個(gè)元素。(2)軟件測(cè)試可分為白盒測(cè)試和黑盒測(cè)試。基本路徑測(cè)試屬于

【2】測(cè)試。(3)符合結(jié)構(gòu)化原則的三種基本控制結(jié)構(gòu)是:選擇結(jié)構(gòu)、循環(huán)結(jié)構(gòu)和

【3】。(4)數(shù)據(jù)庫系統(tǒng)的核心是

【4】(5)在E-R圖中,圖形包括矩形框、菱形框、橢圓框。其中表示實(shí)體聯(lián)系的是

【5】框。(6)表達(dá)式(int)((double)(5/2)+2.5)的值是【6】(7)若變量x、y已定義為int類型且x的值為99,y的值為9,請(qǐng)將輸出語句printf(【7】,x/y);補(bǔ)充完整,使其輸出的計(jì)算結(jié)果形式為:x/y=11(8)有以下程序#include<stdio.h>main(){

charc1,c2;

scanf(“&c”,&c1);

while(c1<65||c1>90)

scanf(“&c”,&c1);

c2=c1+32;

printf(“&c,&c\n”,c1,c2);}程序運(yùn)行輸入65回車后,能否輸出結(jié)果、結(jié)束運(yùn)行(請(qǐng)回答能或不能)【8】。

(9)以下程序運(yùn)行后的輸出結(jié)果是【9】#include<stdio.h>main(){intk=1,s=0;do{if{((k&2)!=0)continue;s+=k;k++;}while(k)10);printf(“s=&d/n”,s);}

(10)下列程序運(yùn)行時(shí),若輸入labced12df<回車>輸出結(jié)果為【10】

#include<stdio.h>main(){char

a=0,ch;while((ch=getchar())!=’\n’){if(a&2!=0&&(ch>’a’&&ch<=’z’))ch=ch-‘a(chǎn)’+’A’;a++;putchar(ch);}printf(“\n”);}(11)有以下程序,程序執(zhí)行后,輸出結(jié)果是【11】#include<stdio.h>voidfun(int*a){a[0=a[1];]}main(){inta[10]={10,9,8,7,6,5,4,3,2,1},i;for(i=2;i>=0;i--)fun{&a};for(i=0;i<10;i++)printf(“&d”,a);printf(“\n”);}(12)請(qǐng)將以下程序中的函數(shù)聲明語句補(bǔ)充完整#include<stdio.h>int【12】;main(){intx,y,(*p)();p=max;printf(“&d\n”,&x,&y);}Intmax(inta,intb){return(a>b/a:b);}(13)以下程序用來判斷指定文件是否能正常打開,請(qǐng)?zhí)羁?include<stdio.h>main(){FILE*fp;if(((fp=fopen(“test.txt”,”r”))==【13】))printf(“未能打開文件!\n”);elseprintf(“文件打開成功!\n”);(14)下列程序的運(yùn)行結(jié)果為【14】#include<stdio.h>#include<string.h>structA{inta;charb[10];double

c;};void

f(struct

A

*t);main(){structAa=(1001,”ZhangDa”,1098,0);f(&a);printf(“&d,&s,&6,if\n”,a.a,a.b,a.c);}voidf(struct

A

*t){strcpy(t->b,”ChangRong”);

}(15)以下程序把三個(gè)NODETYPE型的變量鏈接成一個(gè)簡(jiǎn)單的鏈表,并在while循環(huán)中輸出鏈表結(jié)點(diǎn)數(shù)據(jù)域中的數(shù)據(jù),請(qǐng)?zhí)羁?include<stdio.h>structnode{intdata;structnode*next;};typedefstructnodeNODETYPE;main(){NODETYPEa,b,c,*h,*p;a.data=10;b.data=20;c.data=30;h=&a;b.next=&b;b.next=&c;c.next=’\0’;p=h;while(p){printf(“&d”,p->data);【15】;}}一、選擇題1~10DACDCABABC11~20CBDDACDBCD21~30CDABABACBC31~40ADBCCDBDAC二、選擇題1.192.白盒3.順序結(jié)構(gòu)4.數(shù)據(jù)庫管理系統(tǒng)5.菱形6.47.“x/y=%d”8.不能9.s=010.1AbCeDf2Df11.777765432112.max(inta,intb)13.NULL14.1001ChangRong1008.015.p++或p=p->next2022年9月全國計(jì)算機(jī)等級(jí)考試二級(jí)C語言筆試試題及答案一、選擇題((1)—(10)、(21)—(40)每題2分,(11)—(20)每題1分,共70分)(1)下列數(shù)據(jù)結(jié)構(gòu)中,屬于非線性結(jié)構(gòu)的是A)循環(huán)隊(duì)列B)帶鏈隊(duì)列C)二叉樹D)帶鏈棧(2)下列數(shù)據(jù)結(jié)果中,能夠按照“先進(jìn)后出”原則存取數(shù)據(jù)的是A)循環(huán)隊(duì)列B)棧C)隊(duì)列D)二叉樹(3)對(duì)于循環(huán)隊(duì)列,下列敘述中正確的是A)隊(duì)頭指針是固定不變的B)隊(duì)頭指針一定大于隊(duì)尾指針C)隊(duì)頭指針一定小于隊(duì)尾指針D)隊(duì)頭指針可以大于隊(duì)尾指針,也可以小于隊(duì)尾指針(4)算法的空間復(fù)雜度是指A)算法在執(zhí)行過程中所需要的計(jì)算機(jī)存儲(chǔ)空間B)算法所處理的數(shù)據(jù)量C)算法程序中的語句或指令條數(shù)D)算法在執(zhí)行過程中所需要的臨時(shí)工作單元數(shù)(5)軟件設(shè)計(jì)中劃分模塊的一個(gè)準(zhǔn)則是A)低內(nèi)聚低耦合B)高內(nèi)聚低耦合C)低內(nèi)聚高耦合D)高內(nèi)聚高耦合(6)下列選項(xiàng)中不屬于結(jié)構(gòu)化程序設(shè)計(jì)原則的是A)可封裝D)自頂向下C)模塊化D)逐步求精(7)軟件詳細(xì)設(shè)計(jì)產(chǎn)生的圖如下:該圖是A)N-S圖B)PAD圖C)程序流程圖D)E-R圖(8)數(shù)據(jù)庫管理系統(tǒng)是A)操作系統(tǒng)的一部分B)在操作系統(tǒng)支持下的系統(tǒng)軟件C)一種編譯系統(tǒng)D)一種操作系統(tǒng)(9)在E-R圖中,用來表示實(shí)體聯(lián)系的圖形是A)橢圓圖B)矩形C)菱形D)三角形(10)有三個(gè)關(guān)系R,S和T如下:

其中關(guān)系T由關(guān)系R和S通過某種操作得到,該操作為A)

選擇B)

投影C)

交D)

并(11)以下敘述中正確的是A)程序設(shè)計(jì)的任務(wù)就是編寫程序代碼并上機(jī)調(diào)試B)程序設(shè)計(jì)的任務(wù)就是確定所用數(shù)據(jù)結(jié)構(gòu)C)程序設(shè)計(jì)的任務(wù)就是確定所用算法D)以上三種說法都不完整(12)以下選項(xiàng)中,能用作用戶標(biāo)識(shí)符的是A)voidB)8_8C)_0_D)unsigned(13)閱讀以下程序#include<stdio.h>main(){intcase;floatprintF;printf(“請(qǐng)輸入2個(gè)數(shù):”);scanf(“%d%f”,&case,&pjrintF);printf(“%d%f\n”,case,printF);}該程序編譯時(shí)產(chǎn)生錯(cuò)誤,其出錯(cuò)原因是A)定義語句出錯(cuò),case是關(guān)鍵字,不能用作用戶自定義標(biāo)識(shí)符B)定義語句出錯(cuò),printF不能用作用戶自定義標(biāo)識(shí)符C)定義語句無錯(cuò),scanf不能作為輸入函數(shù)使用D)定義語句無錯(cuò),printf不能輸出case的值(14)表達(dá)式:(int)((double)9/2)-(9)%2的值是A)0B)3C)4D)5(15)若有定義語句:intx=10;,則表達(dá)式x-=x+x的值為A)-20B)-10C)0D)10(16)有以下程序#include<stdio.h>main(){inta=1,b=0;printf(“%d,”,b=a+b);printf(“%d\n”,a=2*b);}程序運(yùn)行后的輸出結(jié)果是A)0,0B)1,0C)3,2D)1,2(17)設(shè)有定義:inta=1,b=2,c=3;,以下語句中執(zhí)行效果與其它三個(gè)不同的是A)if(a>b)c=a,a=b,b=c;B)if(a>b){c=a,a=b,b=c;}C)if(a>b)c=a;a=b;b=c;D)if(a>b){c=a;a=b;b=c;}(18)有以下程序#include<stdio.h>main(){intc=0,k;for(k=1;k<3;k++)switch(k){default:c+=kcase2:c++;break;case4:c+=2;break;}printf(“%d\n”,c);}程序運(yùn)行后的輸出結(jié)果是A)3B)5C)7D)9(19)以下程序段中,與語句:k=a>b?(b>c?1:0):0;功能相同的是A)if((a>b)&&(b>c))k=1;elsek=0;B)if((a>b)||(b>c)k=1;elsek=0;C)if(a<=b)k=0;elseif(b<=c)k=1;D)if(a>b)k=1;elseif(b>c)k=1;elsek=0;(20)有以下程序#include<stdio.h>main(){chars[]={“012xy”};inti,n=0;for(i=0;s[i]!=0;i++)if(s[i]>=’a’&&s[i]<=’z’)n++;printf(“%d\n”,n);}程序運(yùn)行后的輸出結(jié)果是A)0B)2C)3D)5(21)有以下程序#include<stdio.h>main(){intn=2,k=0;while(k++&&n++>2);printf(“%d%d\n”,k,n);}程序運(yùn)行后的輸出結(jié)果是A)02B)13C)57D)12(22)有以下定義語句,編譯時(shí)會(huì)出現(xiàn)編譯錯(cuò)誤的是A)chara=’a’;B)chara=’\n’;C)chara=’aa’;D)chara=’\x2d’;(23)有以下程序#include<stdio.h>main(){charc1,c2;c1=’A’+’8’-‘4’;c2=’A’+’8’-‘5’;printf(“%c,%d\n”,c1,c2);}已知字母A的ASCII碼為65,程序運(yùn)行后的輸出結(jié)果是A)E,68B)D,69C)E,DD)輸出無定值(24)有以下程序#include<stdio.h>voidfun(intp){intd=2;p=d++;printf(“%d”,p);}main(){inta=1;fun(a);printf(“%d\n”,a);}程序運(yùn)行后的輸出結(jié)果是A)32B)12C)21D)22(25)以下函數(shù)findmax擬實(shí)現(xiàn)在數(shù)組中查找最大值并作為函數(shù)值返回,但程序中有錯(cuò)導(dǎo)致不能實(shí)現(xiàn)預(yù)定功能#defineMIN-2147483647intfindmax(intx[],intn){inti,max;for(i=0;i<n;i++){max=MIN;if(max<x[i])max=x[i];}returnmax;}造成錯(cuò)誤的原因是A)定義語句inti,max;中max未賦初值B)賦值語句max=MIN;中,不應(yīng)給max賦MIN值C)語句if(max<x[i])max=x[i];中判斷條件設(shè)置錯(cuò)誤D)賦值語句max=MIN;放錯(cuò)了位置(26)有以下程序#include<stdio.h>main(){intm=1,n=2,*p=&m,*q=&n,*r;r=p;p=q;q=r;printf(“%d,%d,%d,%d\n”,m,n,*p,*q);}程序運(yùn)行后的輸出結(jié)果是A)1,2,1,2B)1,2,2,1C)2,1,2,1D)2,1,1,2(27)若有定義語句:inta[4][10],*p,*q[4];且0≤i<4,則錯(cuò)誤的賦值是A)p=aB)q[i]=a[i]C)p=a[i]D)p=&a[2][1](28)有以下程序#include<stdio.h>#include<string.h>main(){charstr[][20]={“One*World”,“One*Dream!”},*p=str[1];printf(“%d,”,strlen(p));printf(“%s\n”,p);}程序運(yùn)行后的輸出結(jié)果是A)9,One*WorldB)9,One*DreamC)10,One*DreamD)10,One*World(29)有以下程序#include<stdio.h>main(){inta[]={2,3,5,4},i;for(i=0;i<4;i++)switch(i%2){case0:switch(a[i]%2){case0:a[i]++;break;case1:a[i]--;}break;case1:a[i[=0;}for(i=0;i<4;i++)printf(“%d”,a[i]);printf(“\n”);}A)3344B)2050C)3040D)0304(30)有以下程序#include<stdio.h>#include<string.h>main(){chara[10]=”abcd”;printf(“%d,%d\n”,strlen(a),sizeof(a));}程序運(yùn)行后的輸出結(jié)果是A)7,4B)4,10C)8,8D)10,10(31)下面是有關(guān)C語言字符數(shù)組的描述,其中錯(cuò)誤的是A)不可以用賦值語句給字符數(shù)組名賦字符串B)可以用輸入語句把字符串整體輸入給字符數(shù)組C)字符數(shù)組中的內(nèi)容不一定是字符串D)字符數(shù)組只能存放字符串(32)下列函數(shù)的功能是fun(char*a,char*b){while((*b=*a)!=’\0’){a++,b++;}}A)將a所指字符串賦給b所指空間B)使指針b指向a所指字符串C)將a所指字符串和b所指字符串進(jìn)行比較D)檢查a和b所指字符串中是否有’\0’

(33)設(shè)有以下函數(shù)voidfun(intn,char*s){……}則下面對(duì)函數(shù)指針的定義和賦值均是正確的是A)void(*pf)();pf=fun;B)viod*pf();pf=fun;C)void*pf();*pf=fun;D)void(*pf)(int,char);pf=&fun;(34)有以下程序#include<stdio.h>intf(intn);main(){inta=3,s;s=f(a);s=s+f(a);printf(“%d\n”,s);}intf(intn){staticinta=1;n+=a++;returnn;}程序運(yùn)行以后的輸出結(jié)果是A)7B)8C)9D)10(35)有以下程序#include<stdio.h>#definef(x)x*x*xmain(){inta=3,s,t;s=f(a+1);t=f((a+1));printf(“%d,%d\n’,s,t);}程序運(yùn)行后的輸出結(jié)果是A)10,64B)10,10C)64,10D)64,64(36)下面結(jié)構(gòu)體的定義語句中,錯(cuò)誤的是A)structord{intx;inty;intz;};structorda;B)structord{intx;inty;intz;}structorda;C)structord{intx;inty;intz;}a;D)struct{intx;inty;intz;}a;(37)設(shè)有定義:char*c;,以下選項(xiàng)中能夠使字符型指針c正確指向一個(gè)字符串的是A)charstr[]=”string”;c=str;B)scanf(“%s”,c);C)c=getchar();D)*c=”string”;(38)有以下程序#include<stdio.h>

#include<string.h>structA{inta;charb[10];doublec;};structAf(structAt);main(){structAa={1001,”ZhangDa”,1098.0};a=f(a);jprintf(“%d,%s,%6.1f\n”,a.a,a.b,a.c);}structAf(structAt)(t.a=1002;strcpy(t.b,”ChangRong”);t.c=1202.0;returnt;)程序運(yùn)行后的輸出結(jié)果是A)1001,ZhangDa,1098.0B)1001,ZhangDa,1202.0C)1001,ChangRong,1098.0D)1001,ChangRong,1202.0(39)若有以下程序段intr=8;printf(“%d\n”,r>>1);輸出結(jié)果是A)16B)8C)4D)2(40)下列關(guān)于C語言文件的敘述中正確的是A)文件由一系列數(shù)據(jù)依次排列組成,只能構(gòu)成二進(jìn)制文件B)文件由結(jié)構(gòu)序列組成,可以構(gòu)成二進(jìn)制文件或文本文件C)文件由數(shù)據(jù)序列組成,可以構(gòu)成二進(jìn)制文件或文本文件D)文件由字符序列組成,其類型只能是文本文件二、填空題(每空2分,共30分)(1)某二叉樹有5個(gè)度為2的結(jié)點(diǎn)以及3個(gè)度為1的結(jié)點(diǎn),則該二叉樹中共有【1】個(gè)結(jié)點(diǎn)。(2)程序流程圖中的菱形框表示的是【2】。(3)軟件開發(fā)過程主要分為需求分析、設(shè)計(jì)、編碼與測(cè)試四個(gè)階段,其中【3】階段產(chǎn)生“軟件需求規(guī)格說明書。(4)在數(shù)據(jù)庫技術(shù)中,實(shí)體集之間的聯(lián)系可以是一對(duì)一或一對(duì)多或多對(duì)多的,那么“學(xué)生”和“可選課程”的聯(lián)系為【4】。(5)人員基本信息一般包括:身份證號(hào),姓名,性別,年齡等。其中可以作為主關(guān)鍵字的是【5】。(6)若有定義語句:inta=5;,則表達(dá)式:a++的值是【6】。(7)若有語句doublex=17;inty;,當(dāng)執(zhí)行y=(int)(x/5)%2;之后y的值為【7】。(8)以下程序運(yùn)行后的輸出結(jié)果是【8】。#include<stdio.h>main(){intx=20;printf(“%d”,0<x<20);printf(“%d\n”,0<x&&x<20);}(9)以下程序運(yùn)行后的輸出結(jié)果是【9】。#include<stdio.h>main(){inta=1,b=7;do{b=b/2;a+=b;}while(b>1);printf(“%d\n”,a);}(10)有以下程序#include<stdio.h>main(){intf,f1,f2,i;f1=0;f2=1;printf(“%d%d”,f1,f2);for(i=3;i<=5;i++){f=f1+f2;printf(“%d”,f);f1=f2;f2=f;}printf(“\n”);}程序運(yùn)行后的輸出結(jié)果是【10】。(11)有以下程序#include<stdio.h>inta=5;voidfun(intb){inta=10;a+=b;printf(“%d”,a);}main(){intc=20;fun(c);a+=c;printf(“%d\n”,a);}程序運(yùn)行后的輸出結(jié)果是【11】。(12)設(shè)有定義:structperson{intID;charname[12];}p;請(qǐng)將scanf(“%d”,【12】);語句補(bǔ)充完整,使其能夠?yàn)榻Y(jié)構(gòu)體變量p的成員ID正確讀入數(shù)據(jù)。(13)有以下程序#include<stdio.h>main(){chara[20]=”Howareyou?”,b[20];scanf(“%s”,b);printf(“%s%s\n”,a,b);}程序運(yùn)行時(shí)從鍵盤輸入:Howareyou?<回車>則輸出結(jié)果為【13】。(14)有以下程序#include<stdio.h>typedefstruct{intnum;doubles}REC;voidfun1(RECx){x.num=23;x.s=88.5;}main(){RECa={16,90.0};fun1(a);printf(“%d\n”,a.num);}程序運(yùn)行后的輸出結(jié)果是【14】。(15)有以下程序#include<stdio.h>fun(intx){if(x/2>0)run(x/2);printf(“%d”,x);}main(){fun(6);printf(“\n”);}程序運(yùn)行后的輸出結(jié)果是【15】。一、選擇題1~10CBDABACBCD11~20DCABBDCAAB21~30DCACDBACCB31~40DAACABADCC二、選擇題1.142.邏輯條件3.需求分析4.多對(duì)多5.身份證號(hào)6.57.18.109.510.0112311.302512.&p.ID13.Howareyou?How14.1615.1362010年3月全國計(jì)算機(jī)等級(jí)考試二級(jí)筆試試卷C語言程序設(shè)計(jì)及參考答案(考試時(shí)間90分鐘,滿分100分)一、選擇題((1)—(10)、(21)—(40)每題2分,(11)—(20)每題1分。共70分)下列各題A)、B)、C)、D)四個(gè)選項(xiàng)中,只有一個(gè)選項(xiàng)是正確的,請(qǐng)將正確選項(xiàng)涂寫在答題卡上,答在試卷上不得分。(1)下列敘述中正確的是A)對(duì)長(zhǎng)度為n的有序鏈表進(jìn)行查找,最壞情況下需要的比較次數(shù)為nB)對(duì)長(zhǎng)度為n的有序鏈表進(jìn)行對(duì)分查找,最壞情況下需要的比較次數(shù)為(n/2)C)對(duì)長(zhǎng)度為n的有序鏈表進(jìn)行對(duì)分查找,最壞情況下需要的比較次數(shù)為(log2n)D)對(duì)長(zhǎng)度為n的有序鏈表進(jìn)行對(duì)分查找,最壞情況下需要的比較次數(shù)為(nlog2n)(2)算法的時(shí)間復(fù)雜度是指

A)算法的執(zhí)行時(shí)間

B)算法所處理的數(shù)據(jù)量

C)算法程序中的語句或指令條數(shù)

D)算法在執(zhí)行過程中所需要的基本運(yùn)算次數(shù)(3)軟件按功能可以分為:應(yīng)用軟件、系統(tǒng)軟件和支撐軟件(或工具軟件)。下面屬于系統(tǒng)軟件的是

A)編輯軟件

B)操作系統(tǒng)

C)教務(wù)管理系統(tǒng)

D)瀏覽器(4)軟件(程序)調(diào)試的任務(wù)是

A)診斷和改正程序中的錯(cuò)誤

B)盡可能多地發(fā)現(xiàn)程序中的錯(cuò)誤

C)發(fā)現(xiàn)并改正程序中的所有錯(cuò)誤

D)確定程序中錯(cuò)誤的性質(zhì)(5)數(shù)據(jù)流程圖(DFD圖)是

A)軟件概要設(shè)計(jì)的工具

B)軟件詳細(xì)設(shè)計(jì)的工具

C)結(jié)構(gòu)化方法的需求分析工具

D)面向?qū)ο蠓椒ǖ男枨蠓治龉ぞ?6)軟件生命周期可分為定義階段,開發(fā)階段和維護(hù)階段。詳細(xì)設(shè)計(jì)屬于

A)定義階段

B)開發(fā)階段

C)維護(hù)階段

D)上述三個(gè)階段(7)數(shù)據(jù)庫管理系統(tǒng)中負(fù)責(zé)數(shù)據(jù)模式定義的語言是

A)數(shù)據(jù)定義語言

B)數(shù)據(jù)管理語言

C)數(shù)據(jù)操縱語言

D)數(shù)據(jù)控制語言(8)在學(xué)生管理的關(guān)系數(shù)據(jù)庫中,存取一個(gè)學(xué)生信息的數(shù)據(jù)單位是

A)文件

B)數(shù)據(jù)庫

C)字段

D)記錄(9)數(shù)據(jù)庫設(shè)計(jì)中,用E-R圖來描述信息結(jié)構(gòu)但不涉及信息在計(jì)算機(jī)中的表示,它屬于數(shù)據(jù)庫設(shè)計(jì)的

A)需求分析階段

B)邏輯設(shè)計(jì)階段C)概念設(shè)計(jì)階段D)物理設(shè)計(jì)階段

(10)有兩個(gè)關(guān)系R和T如下:R

TABCa12b22c32ABCc32d32則由關(guān)系R得到關(guān)系T的操作是A)選擇

B)投影

C)交

D)并(11)以下敘述正確的是A)C語言程序是由過程和函數(shù)組成的B)C語言函數(shù)可以嵌套調(diào)用,例如:fun(fun(x))C)C語言函數(shù)不可以單獨(dú)編譯D)C語言中除了main函數(shù),其他函數(shù)不可以作為單獨(dú)文件形式存在(12)以下關(guān)于C語言的敘述中正確的是A)C語言中的注釋不可以夾在變量名或關(guān)鍵字的中間B)C語言中的變量可以再使用之前的任何位置進(jìn)行定義C)在C語言算術(shù)的書寫中,運(yùn)算符兩側(cè)的運(yùn)算數(shù)類型必須一致D)C語言的數(shù)值常量中夾帶空格不影響常量值的正確表示(13)以下C語言用戶標(biāo)示符中,不合法的是A)_1

B)AaBc

C)a_b

D)a--b(14)若有定義:doublea=22;inti=0,k=18;則不符合C語言規(guī)定的賦值語句是A)a=a++,i++

B)i=(a+k)<=(i+k)

C)i=a%11

D)i=!a(15)#include<stdio.h>main(){chara,b,c,d;scanf("%c%c",&a,&b);c=getchar();

d=getchar();printf("%c%c%c%c\n",a,b,c,d);}當(dāng)執(zhí)行程序時(shí),按下列方式輸入數(shù)據(jù)(從第一列開始,<CR>代表回車,注意:回車是一個(gè)字符)12<CR>34<CR>則輸出結(jié)果是:A)1234

B)12

C)12

D)12

3

34(16)以下關(guān)于C語言數(shù)據(jù)類型使用的敘述中錯(cuò)誤的是:A)若要準(zhǔn)確無誤的表示自然數(shù),應(yīng)使用整數(shù)類型。B)若要保存帶有多位小數(shù)的數(shù)據(jù),應(yīng)使用雙精度類型。C)若要處理如"人員信息"等含有不同類型的相關(guān)數(shù)據(jù),應(yīng)自定義結(jié)構(gòu)體類型。D)若只處理"真"和"假"兩種邏輯值,應(yīng)使用邏輯類型。(17)若a是數(shù)值類型,則邏輯表達(dá)式(a==1)||(a!=1)的值是:A)1

B)0

C)2

D)不知道a的值,不能確定(18)以下選項(xiàng)中與if(a==1)a=b;elsea++;語句功能不同的switch語句是:A)switch(a)

B)switch(a==1)

{case1:a=b;break;

{

case0:a=b;break;

default:a++;

case1:a++;}

}C)switch(a)

D)switch(a==1)

{

default:a++;break;

{

case1:a=b;break;

case1:a=b;

case0:a++;}

}(19)有如下嵌套的if語句

if(a<b)

if(a<c)

k=a;

else

k=c;

else

if(b<c)

k=b;

else

k=c;以下選項(xiàng)中與上述if語句等價(jià)的語句是A)k=(a<b)?a:b;k=(b<c)?b:c;B)k=(a<b)?((b<c)?a:b):((b<c)?b:c);C)k=(a<b)?((a<c)?a:c):((b<c)?b:c);D)k=(a<b)?a:b;k=(a<c)?a;c(20)有以下程序#include

<stdio.h>main(){inti,j,m=1;for(i=1;i<3;i++){for(j=3;j>0;j--){if(i*j>3)break;m*=i*j;}}printf("m=%d\n",m)}程序運(yùn)行后的輸出結(jié)果是A)m=6

B)m=2

C)m=4

D)m=5

(21)有以下程序#includes<stdio.h>main(){inta=1,b=2;

for(;a<8;a++){b+=a;a+=2;}printf("%d,%d\n",a,b);}程序運(yùn)行后的輸出結(jié)果是A)9,18

B)8,11

C)7,11

D)10,14(22)有以下程序,其中k的初值為八進(jìn)制數(shù)#include<stdio.h>main(){intk=011;printf("%d\n",k++);}程序運(yùn)行后的輸出結(jié)果是A)12

B)11

C)10

D)9(23)下列語句中,正確的是A)char*s;s="Olympic";

B)chars[7];s="Olympic";C)char*s;s={"Olympic"};

D)chars[7];s={"Olympic"};(24)以下關(guān)于return語句的敘述中正確的是A)一個(gè)自定義函數(shù)中必須有一條return語句B)一個(gè)自定義函數(shù)中可以根據(jù)不同情況設(shè)置多條return語句C)定義成viod類型的函數(shù)中可以有帶返回值的return語句D)沒有return語句的自定義函數(shù)在執(zhí)行結(jié)束時(shí)不能返回到調(diào)用處

(25)下列選項(xiàng)中,能夠正確定義數(shù)組的語句是A)intnum[0..2008];

B)intnum[];C)intN=2008;

D)#defineN2008

intnum[N];

intnum[N](26)有以下程序#include<stdio.h>voidfun(char*c,intd){*c=*c+1;d=d+1;printf("%c,%c,",*c,d);}main(){charb=’a’,a=’A’;

fun(&b,a);printf("%c,%c\n",b,a);}程序運(yùn)行后的輸出結(jié)果是

A)b,B,b,A

B)b,B,B,A

C)a,B,B,a

D)a,B,a,B

(27)若有定義int(*pt)[3];,則下列說法正確的是A)定義了基類型為int的三個(gè)指針變量B)定義了基類型為int的具有三個(gè)元素的指針數(shù)組pt。C)定義了一個(gè)名為*pt、具有三個(gè)元素的整型數(shù)組D)定義了一個(gè)名為pt的指針變量,它可以指向每行有三個(gè)整數(shù)元素的二維數(shù)組

(28)設(shè)有定義doublea[10],*s=a;,一下能夠代表數(shù)組元素a[3]的是A)(*s)[3]

B)*(s+3)

C)*s[3]

D)*s+3

(29)有以下程序#include<stdio.h>main(){inta[5]={1,2,3,4,5},b[5]={0,2,1,3,0},is=0

for(i=0;i<5;i++)s=s+a[b[i]];printf("%d\n",s);}程序運(yùn)行后的輸出結(jié)果是A)6

B)10

C)11

D)1530)有以下程序

#include<stdio.h>

main(){intb[3][3]={0,1,2,0,1,2,0,1,2},i,j,t=1;

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

t+=b[i][b[j][i]];Printf("%d\n",t);}程序運(yùn)行后的輸出結(jié)果是A)1

B)3

C)4

D)9(31)若有以下定義和語句charsl[10]="abcd!",*s2="n123\\";

printf("%d%d\n",strlen(s1),strlen(s2));則輸出結(jié)果是A)55

B)105

C)107

D)58(32)有以下程序

#include<stdio.h>

#defineN8

voidfun(int

*x,inti)

{*x=*(x+i);}main(){inta[N]={1,2,3,4,5,6,7,8},i;fun(a,2);for(i=0;i<N/2);i++){printf("%d",a[i]);}printf("\n");}程序運(yùn)行后的輸出結(jié)果是A)1313

B)2234

C)3234

D)1234(33)有以下程序#include<studio.h>intf(intt[],intn);main(){inta[4]={1,2,3,4},s;s=f{a,4};printf("%d\n",s);}intf(intt[],intn){if(n>0)

returnt[n-1]+f(t,n-1);else

return0;}程序運(yùn)行后的輸出結(jié)果是A)4

B)10

C)14

D)6

(34)有以下程序#include<studio.h>intfun(){staticint

x=1;x*=2;return

x;}main(){intI,s=1;for(i=1;i<=2;i++)

s=fun();printf("%d\n",s);}程序運(yùn)行后的輸出結(jié)果是A)0

B)1

C)4

D)8(35)以下程序#include<stdio.h>#define

SUB(a)

(a)-(a)main(){int

a=2,b=3,c=5,d;d=SUB(a+b)*c;printf("%d\n",d);}程序運(yùn)行后的結(jié)果是A)0

B)-12

C)-20

D)10(36)沒有定義structcomplex{

int

real,unreal;}datal={1,8},data2;則以下賦值語句中的錯(cuò)誤的是A)data2=data1;

B)data2=(2,6);C)data2.real1=data1.real;

D)data2.real=data1.unreal;

(37)有以下程序#include<studio.h>#include<string.h>structA{inta;charb[10];doublec;};voidf(struct

A

t);main(){struct

A

a={1001,"ZhangDa",1098.0};f(a);pringt("%d,%s,%6.1f\n",a.a,a.b,a.c);}voidf(struct

A

t){t.a=1002;strcpy(t.b,"ChangRong");t.c=1202.0;}程序運(yùn)行后的輸出結(jié)果是A)1001,ZhangDa,1098.0

B)1002,ChangRong,1202.0C)1001,ChangRong,1098.0

D)1002,ZhangDa,1202.0(38)有以下定義和語句struct

workers{int

num;charname[20];charc;srruct{intday;intmonth;intyear;}s;};structworkers

w,*pw;pw=&w能給w中year成員賦1980的語句是A)*pw.year=1980;

B)w.year=1980;C)pw->year=1980;

D)w.s.year=1980;(39)有以下程序#include<stdio.h>main(){inta=2,b=2,c=2;printf("%d\n",a/b&c);}程序運(yùn)行后的結(jié)果是A)0

B)1

C)2

D)3(40)以下程序#include<stdio.h>main(){

FILE

*fp;char

str[10];fp=fopen("myfile.dat","w");fputs("abc",fp);

fclose(fp);fp=fopen("myfile.dat","a+");rewind(fp,"gd",28);rewind(fp);fscanf(fp,"gs",str);

puts(str);fclose(fp);}程序運(yùn)行后的輸出結(jié)果是A)abc

B)28c

C)abc28

D)因類型不一致而出錯(cuò)二、填空題(每空2分,共30分)請(qǐng)將每空的正確答案寫在答題卡【1】至【15】序號(hào)的橫線上,答在試卷上不得分。(1)一個(gè)隊(duì)列的初始狀態(tài)為空,先將元素A,CB,C,D,E,F,5,4,3,2,1依次入隊(duì),然后再依次退隊(duì),則元素退隊(duì)的順序?yàn)開__【1】__。(2)設(shè)某循環(huán)列隊(duì)的容量為50,如果頭指針front=45(指向隊(duì)頭元素的前一位置),尾指針rear=10(指向隊(duì)尾元素),則該循環(huán)隊(duì)列中共有___【2】__個(gè)元素。(3)設(shè)二叉數(shù)如下:對(duì)該二叉樹進(jìn)行后序遍歷的結(jié)果為【3】(4)軟件是

【4】

、數(shù)據(jù)和文檔的集合。(5)有一個(gè)學(xué)生選課的關(guān)系,其中學(xué)生的關(guān)系模式為:學(xué)生(學(xué)號(hào),姓名,班級(jí),年齡),課程的關(guān)系模式為:課程(課號(hào),課程名,學(xué)時(shí)),其中兩個(gè)關(guān)系模式的鍵分別是學(xué)好和課號(hào),則關(guān)系模式選課可以定義為:選課(學(xué)號(hào),

【5】

,成績(jī))。(6)設(shè)x為int型變量,請(qǐng)寫出一個(gè)關(guān)系表達(dá)式

【6】

,用以判斷x同時(shí)為3和7的倍數(shù)時(shí),關(guān)系表達(dá)式的值為真。(7)有以下程序#include<stdio.h>main(){inta=1,b=2,c=3,d=0;if(a==1)

if(b!=2)

if(c!=3)

d=1;

else

d=2;

elseif(c!=3)

d=3;

else

d=4;

else

d=5;

printf("%d\n",d);}程序運(yùn)行后的輸出結(jié)果是:

【7】

。(8)有以下程序#include<stdio.h>main(){

intm,n;scanf("%d%d",&m,&n);while(m!=n){

while(m>n)m=m-n;

while(m<n)n=n-m;}printf("%d\n",m);}程序運(yùn)行后,當(dāng)輸入14

63<回車>時(shí),輸出結(jié)果是

【8】

(9)有以下程序#include<stdio.h>main(){

intI,j,a[][3]={1,2,3,4,5,6,7,8,9};

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

for(j=I;j<3;j++)

printtf("%d",a[i][j]);

printf("\n");}程序運(yùn)行后的輸出結(jié)果是

【9】

(10)有以下程序

#include<stdio.h>main(){

int

[]={1,2,3,4,5,6},*k[3],i=0;

while(i<3)

{

k[i]=&a[2*i];

printf("%d",*k[i]);

i++;

}}程序運(yùn)行后的輸出結(jié)果是__________(11)有以下程序

#include<stdio.h>main(){

int

a[3][3]={{1,2,3},{4,5,6},{7,8,9}};

int

b[3]={0},i;

for(i=0;i<3;i++)b[i]=a[i][2]+a[2][i];

for(i=0;i<3;i++)printf("%d",b[i]);

printf("\n");}程序運(yùn)行后的結(jié)果是____________(12)有以下程序#include<stdio.h>#include<string.h>voidfun(char*str){

chartemp;

intn,i;

n=strlen(str);

temp=str[n-1];

for(i=n-1;i>0;i--)str[i]=str[i-1];

str[0]=temp;}main(){

chars[50];

scanf("%s",s);

fun(s);

printf("%s\n",s);}程序運(yùn)行后輸入:abcdef<回車>,則輸出結(jié)果是____________(13)以下程序的功能是:將值為三位正整數(shù)的變量x中的數(shù)值按照個(gè)位、十位、百位的順序拆分并輸出。請(qǐng)?zhí)羁铡?include<stdio.h>main(){

intx=256;

printf("%d-%d-%d\n",

,x/10%10,x/100);}

(14)以下程序用以刪除字符串中的所有的空格,請(qǐng)?zhí)羁铡?include<stdio.h>main(){

char

s[100]={"our.tercherteach

clanguage!"};inti,j;for(i=j=0;s[i]!=‘\0’;i++)

if(s[i]!=‘’){s[j]=s[i];j++;}s[j]=

;printf("%s\n",s);}

(15)以下程序功能是:借助指針變量找出數(shù)組元素中的最大值及其元素的下標(biāo)值。請(qǐng)?zhí)羁铡?include<stdio.h>main(){

inta[10],*p,*s;

for(p=a;p-a<10;p++)scanf("%d",p);

for(p=a,s=a;p-a<10;p++)

if(*p>*s)s=_______________;

printf("index=%d\n",s-a);}

參考答案

一、選擇題:1-5ADBAC

6-10BADCA

11-15BBDCC

16-20DABCA

21-25DDABD

26-30ADBCC

31-35ACBCC

36-40BADAC二、填空題1、ABCDEF543212、153、EDBGHFCA4、程序5、課號(hào)6、(x%3==0)&&(x%7==0)7、48、79、12356910、13511、10141812、fabcde13、x%1014、'\0'或者填寫015、p2010年9月全國計(jì)算機(jī)二級(jí)C語言筆試試題一、選擇題(每小題2分,共70分)

下列各題A)、B)、C)、D)四個(gè)選項(xiàng)中,只有一個(gè)選項(xiàng)是正確的。請(qǐng)將正確選項(xiàng)填涂在答題卡相應(yīng)位置上,答在試卷上不得分。

(1)下列敘述中正確的是

A)線性表的鏈?zhǔn)酱鎯?chǔ)結(jié)構(gòu)與順序存儲(chǔ)結(jié)構(gòu)所需要的存儲(chǔ)空間是相同的

B)線性表的鏈?zhǔn)酱鎯?chǔ)結(jié)構(gòu)所需要的存儲(chǔ)空間一般要多于順序存儲(chǔ)結(jié)構(gòu)

C)線性表的鏈?zhǔn)酱鎯?chǔ)結(jié)構(gòu)所需要的存儲(chǔ)空間一般要少于順序存儲(chǔ)結(jié)構(gòu)

D)上述三種說法都不對(duì)

(2)下列敘述中正確的是

A)在棧中,棧中元素隨棧底指針與棧頂指針的變化而動(dòng)態(tài)變化

B)在棧中,棧頂指針不變,棧中元素隨棧底指針的變化而動(dòng)態(tài)變化

C)在棧中,棧底指針不變,棧中元素隨棧頂指針的變化而動(dòng)態(tài)變化

D)上述三種說法都不對(duì)

(3)軟件測(cè)試的目的是

A)評(píng)估軟件可靠性

B)發(fā)現(xiàn)并改正程序中的錯(cuò)誤

C)改正程序中的錯(cuò)誤

D)發(fā)現(xiàn)程序中的錯(cuò)誤

(4)下面描述中,不屬于軟件危機(jī)表現(xiàn)的是

A)軟件過程不規(guī)范

B)軟件開發(fā)生產(chǎn)率低

C)軟件質(zhì)量難以控制

D)軟件成本不斷提高

(5)軟件生命周期是指

A)軟件產(chǎn)品從提出、實(shí)現(xiàn)、使用維護(hù)到停止使用退役的過程

B)軟件從需求分析、設(shè)計(jì)、實(shí)現(xiàn)到測(cè)試完成的過程

C)軟件的開發(fā)過程

D)軟件的運(yùn)行維護(hù)過程(6)面向?qū)ο蠓椒ㄖ?,繼承是指

A)一組對(duì)象所具有的相似性質(zhì)

B)一個(gè)對(duì)象具有另一個(gè)對(duì)象的性質(zhì)

C)各對(duì)象之間的共同性質(zhì)

D)類之間共享屬性和操作的機(jī)制

(7)層次型、網(wǎng)狀型和關(guān)系型數(shù)據(jù)庫劃分原則是

A)記錄長(zhǎng)度

B)文

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(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ì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論