08~09年過計算機(jī)c語言試題和答案_第1頁
08~09年過計算機(jī)c語言試題和答案_第2頁
08~09年過計算機(jī)c語言試題和答案_第3頁
08~09年過計算機(jī)c語言試題和答案_第4頁
08~09年過計算機(jī)c語言試題和答案_第5頁
已閱讀5頁,還剩63頁未讀 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

2009年9月全國計算機(jī)等級考試二級筆試試卷

1)下列數(shù)據(jù)結(jié)構(gòu)中,屬于非線性結(jié)構(gòu)的是

A)循環(huán)隊列B)帶鏈隊列C)二叉樹D)帶鏈棧

2)下列數(shù)據(jù)結(jié)果中,能夠按照“先進(jìn)后出”原則存取數(shù)據(jù)的是

A)循環(huán)隊列B)棧C)隊列D)二叉樹

3)對于循環(huán)隊列,下列敘述中正確的是

A)隊頭指針是固定不變的B)隊頭指針一定大于隊尾指針C)隊頭指針一定小于隊尾指

針D)隊頭指針可以大于隊尾指針,也可以小于隊尾指針

4)算法的空間復(fù)雜度是指

A)算法在執(zhí)行過程中所需要的計算機(jī)存儲空間B)算法所處理的數(shù)據(jù)量C)算法程

序中的語句或指令條數(shù)

D)算法在執(zhí)行過程中所需要的臨時工作單元數(shù)

5)軟件設(shè)計中劃分模塊的一個準(zhǔn)則是

A)低內(nèi)聚低耦合B)高內(nèi)聚低耦合C)低內(nèi)聚高耦合D)高內(nèi)聚高耦合

6)下列選項中不屬于結(jié)構(gòu)化程序設(shè)計原則的是

A)可封裝B)自頂向下C)模塊化D)逐步求精

7)軟件詳細(xì)設(shè)計產(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圖中,用來表示實體聯(lián)系的圖形是

A)橢圓圖B)矩形C)菱形D)三角形

10)有三個關(guān)系R,S和T如下:

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

A)選擇B)投影C)交D)并

11)以下敘述中正確的是A)程序設(shè)計的任務(wù)就是編寫程序代碼并上機(jī)

B)程序設(shè)計的任務(wù)就是確定所用數(shù)據(jù)結(jié)構(gòu)

O程序設(shè)計的任務(wù)就是確定所用算法

D)以上三種說法都不完整

12)以下選項中,能用作用戶標(biāo)識符的是

A)voidB)8_8C)_0_D)unsigned

13)閱讀以下程序

#include<stdio.h>

main()

{intcase;floatprintF;

printf(〃請輸入2個數(shù):”);

scanf(z/%d%f〃,&case,&pjrintF);

printf(z/%d%f\n/\case,printF);

該程序編譯時產(chǎn)生錯誤,其出錯原因是

A)定義語句出錯,case是關(guān)鍵字,不能用作用戶自定義標(biāo)識符B)定義語句出錯,printF

不能用作用戶自定義標(biāo)識符

C)定義語句無錯,scanf不能作為輸入函數(shù)使用D)定義語句無錯,printf不能輸出case

的值

14)表達(dá)式:(intX(double)9/2)?(9)%2的值是

A)0B)3C)4D)5

15)若有定義語句:intx=10;,則表達(dá)式x?=x+x的值為

A)-20B)-IOC)0D)10

16)有以下程序

#include<stdio.h>

main()

{inta=lzb=0;

printf(z/%d/;b=a+b);

printf(//%d\n,;a=2*b);

)

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

A)0,0B)1,0C)3,2D)1,2

17)設(shè)有定義:inta=l,b=2,c=3;,以下語句中執(zhí)行效果與其它三個不同的是

A)if(a>b)c=aza=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=0zk;

for(k=l;k<3;k++)

switch(k)

{default:c+=k

case2:c++;break;

case4:c+=2;break;

)

printf(〃%d\n”,c);

}

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

A)3B)5C)7D)9

19)以下程序段中,與語句:k=a>b?(b>c?l:0):0;功能相同的是

A)if((a>b)&&(b>c))k=l;elsek=0;

B)if((a>b)||(b>c)k=l;elsek=0;

C)if(a<=b)k=0;elseif(b<=c)k=l;

D)if(a>b)k=l;elseif(b>c)k=l;elsek=0;

20)有以下程序

#include<stdio.h>

main()

/,,

,chars*+=/012xy};intizn=0;

for(i=0;s[i]!=0;i++)

if(s*i+>=/a/&&s*i+<=,z/)n++;

printf("%d\n\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);

}程序運行后的輸出結(jié)果是

A)02B)13C)57D)12

22)有以下定義語句,編譯時會出現(xiàn)編譯錯誤的是

A)chara=Ja'B)chars=9\n';C)chara=>aa';D)chara=f\x2d,;

23)有以下程序

#include<stdio.h>

main()

{charcl,c2;

cl='A'+'8'-4;

c2='A'+'8',5';

printf(〃%c,%d\n〃,cl,c2);

)

已知字母A的ASCII碼為65,程序運行后的輸出結(jié)果是

A)E,68B)D,69C)E,DD)輸出無定值

24)有以下程序

#include<stdio.h>

voidfun(intp)

{intd=2;

p=d++;printf(〃%d〃,p);}

main()

{inta=l;

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

A)32B)12C)21D)22

25)以下函數(shù)findmax擬實現(xiàn)在數(shù)組中查找最大值并作為函數(shù)值返回,但程序中有錯導(dǎo)致不

能實現(xiàn)預(yù)定功能

#defineMIN-2147483647

intfindmax(intx[],intn)

{inti,max;

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

{max=MIN;

if(max<x[i])max=x[i];}

returnmax;

}造成錯誤的原因是

A)定義語句inti,max;中max未賦初值B)賦值語句max二MIN;中,不應(yīng)給max賦MIN

C)語句if(max<x[i])max=x[i];中判斷條件設(shè)置錯D)賦值語句max二MIN;放錯了位置

(26)有以下程序

#include<stdio.h>

main()

{intm=l/n=2,*p=&m/*q=&n/*r;

r=p;p=q;q=r;

printf("%d,%d,%d,%d\n〃,m,n,*p,*q);

}程序運行后的輸出結(jié)果是

A)1,2,1,B)1,2,2」C)2,1,2,D)2,1,1,2

27)若有定義語句:intapl][10],*p,*q[4];R.0Wi<4,則錯誤的賦值是

A)p=aB)q[i]=a[i]C)p=a[i]D)p=&a[2][l]

28)有以下程序

#include<stdio.h>

#include<string.h>

main()

/,/z,,

,charstr*]*20]=/One*World\One*Dream!}z*p=str*l];

printf("%d,〃,strlen(p));printf("%s\n〃,p);

}程序運行后的輸出結(jié)果是

A)9,One*WorldB)9,0ne*DreamC)10,One*DreamD)10,One*World

29)有以下程序

#include<stdio.h>

main()

{inta[卜{2,354},i;

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

switch(i%2)

{case0:switch(a[i]%2)

{caseO:a[i]++;break;

casel:a[i]-;

Jbreak;

casel:a[i[=O;

)

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);

}程序運行后的輸出結(jié)果是

A)7,4B)4,10C)8,8D)10,10

31)下面是有關(guān)C語言字符數(shù)組的描述,其中錯誤的是

A)不可以用賦值語句給字符數(shù)組名賦字符串B)可以用輸入語句把字符串整體輸入給字

符數(shù)組

C)字符數(shù)組中的內(nèi)容不一定是字符串D)字符數(shù)組只能存放字符串

32)下列函數(shù)的功能是

fun(char*a,char*b)

{while((*b=*a)!=,\Oz){a++{b++;}}

A)將a所指字符串賦給b所指空間B)使指針b指向a所指字符串C)將a所指字符串

和b所指字符串進(jìn)行比較

D)檢查a和b所指字符串中是否有‘\0'

33)設(shè)有以下函數(shù)

voidfun(intn,char*s){.......}則卜面對函數(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(/z%d\nw{s);

)

intf(intn)

{staticinta=l;

n+=a++;

returnn;

}程序運行以后的輸出結(jié)果是

A)7B)8C)9D)10

35)有以下程序

#include<stdio.h>

#definef(x)x*x*x

main()

{inta=3,s,t;

s=f(a+l);t=f((a+l));

printf("%d{%d\n,{s{t);

}程序運行后的輸出結(jié)果是

A)10,64B)10,10C)64,10D)64,64

36)下面結(jié)構(gòu)體的定義語句中,錯誤的是

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;,以下選項中能夠使字符型指針c正確指向一個字符串的是

A)charstr[]=wstring;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()

{structA

a={100irZhangDaw{1098.0};

a=f(a);jprintf(z/%d{%s{%6.1An7/{a.a{a.b{a.c);

)

structAf(structAt)

(t.a=1002;strcpy(t.bZ,ChangRongn);t.c=1202.0;returnt;)程序運行后的輸出結(jié)果是

A)1001,ZhangDa,1098.0B)lOOLZhangDa,1202.0C)1001,ChangRong,1098.0D)

1001,ChangRong,1202.0

39)若有以下程序段

intr=8;

printf(“%d\n”,r?l);輸出結(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個度為2的結(jié)點以及3個度為1的結(jié)點,則該二叉樹中共有【1】個結(jié)點。

2)程序流程圖中的菱形框表示的是【2】。

3)軟件開發(fā)過程主要分為需求分析、設(shè)計、編碼與測試四個階段,其中【3】階段產(chǎn)生“軟

件需求規(guī)格說明書。

4)在數(shù)據(jù)庫技術(shù)中,實體集之間的聯(lián)系可以是一對一一或一對多或多對多的,那么“學(xué)生”

和“可選課程”的聯(lián)系為【4】。

5)人員基本信息一般包括:身份證號,姓名,性別,年齡等。其中可以作為主關(guān)鍵字的是【5】。

6)若有定義語句:inta=5;,則表達(dá)式:a++的值是【6】。

7)若有語句doublex=17;inty;,當(dāng)執(zhí)行y=(int"x/5)%2;之后y的值為【7】。

8)以下程序運行后的輸出結(jié)果是[8】o

#include<stdio.h>

main()

{intx=20;

printf(//%d//{0<x<20);

printf(//%d\n,,{0<x&&x<20);}

9)以下程序運行后的輸出結(jié)果是[9】。

#include<stdio.h>

main()

{inta=l,b=7;

do{

b=b/2;a+=b;

}while(b>l);

printf(〃%d\n〃{a);}

10)有以下程序

#include<stdio.h>

main()

{intf,fl,f2,i;

fl=0;f2=l;

printf("%d%d〃,fl,f2);

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

zf=fl+f2;printf(〃%d〃,f);

fl=f2;f2=f;

)

printf(〃\n〃);

}程序運行后的輸出結(jié)果是[10]o

11)有以下程序

#include<stdio.h>

inta=5;

voidfun(intb)

{inta=10;

a+=b;printf(//%d,,,a);

)

main()

{intc=20;

fun(c);a+=c;printf(zz%d\n\a);

}程序運行后的輸出結(jié)果是[111O

12)設(shè)有定義:

structperson

{intID;charname[12];}p;

請將scanf(“%d”,[12]);語句補充完整,使其能夠為結(jié)構(gòu)體變量p的成員ID正確讀入

數(shù)據(jù)。

13)有以下程序

#include<stdio.h>

main()

,chara[20+=MHowareyou??,,b[20+;

scanf("%s",b);printf("%s%s\n",a,b);

}程序運行時從鍵盤輸入:Howareyou?〈回車〉則輸出結(jié)果為【13】。

14)有以下程序

#include<stdio.h>

typedefstruct

{intnum;doubles}REC;

voidfunl(RECx){x.num=23;x.s=88.5;}

main()

{RECa={16,90.0};

funl(a);

printf(〃%d\n〃,a.num);

}程序運行后的輸出結(jié)果是【14】

15)有以下程序

#include<stdio.h>

fun(intx)

{if(x/2>0)run(x/2);

printf(〃%d〃,x);

}

main()

{fun(6);printf(“\n");}程序運行后的輸出結(jié)果是【15】。

2009年3月二級C語言筆試真題及答案

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

A)棧是“先進(jìn)先出”的線性表B)隊列是“先進(jìn)先出”的線性表

C)循環(huán)隊列是非線性結(jié)構(gòu)D)有序性表既可以采用順序存儲結(jié)構(gòu),也可以采用鏈

式存儲結(jié)構(gòu)

(2)支持子程序調(diào)用的數(shù)據(jù)結(jié)構(gòu)是A)棧B)樹C)隊列D)二叉樹

(3)某二叉樹有5個度為2的結(jié)點,則該二叉樹中的葉子結(jié)點數(shù)是A)10B)806D)

4

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

A)冒泡排序B)簡單選擇排序C)直接插排序D)堆排序

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

軟件的是

A)編譯軟件B)操作系統(tǒng)C)教務(wù)管理系統(tǒng)D)匯編程序

(6)下面敘述中錯誤的是

A)軟件測試的目的是發(fā)現(xiàn)錯誤并改正錯誤B)對被調(diào)試的程序進(jìn)行“錯誤定位”是程序

調(diào)試的必要步驟

C)程序調(diào)試通常也稱為DebugD)軟件測試應(yīng)嚴(yán)格執(zhí)行測試計劃,排除測試

的隨意性

(7)耦合性和內(nèi)聚性是對模塊獨立性度量的兩個標(biāo)準(zhǔn)。下列敘述中正確的是

A)提高耦合性降低內(nèi)聚性有利于提高模塊的獨立性B)降低耦合性提高內(nèi)聚性有利于提

高模塊的獨立性

C)耦合性是指一個模塊內(nèi)部各個元素間彼此結(jié)合的緊密程度D)內(nèi)聚性是指模塊間互相

連接的緊密程度

(8)數(shù)據(jù)庫應(yīng)用系統(tǒng)中的核心問題是

A)數(shù)據(jù)庫設(shè)計B)數(shù)據(jù)庫系統(tǒng)設(shè)計C)數(shù)據(jù)庫維護(hù)D)數(shù)據(jù)庫管理員培訓(xùn)

(9)有兩個關(guān)系R,S如下:

R

ABC

a32

b01

c21

S

AB

a3

b0

c2

由關(guān)系R通過運算得到關(guān)系S,則所使用的運算為A)選擇B)投影C)插入D)連接

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

(11)以下選項中合法的標(biāo)識符是A)1-1B)1—10-11D)1-

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

A)系統(tǒng)將自動給k賦初值0B)這時k中值無定義C)系統(tǒng)將自動給k賦初值-ID)這時k

中無任何值

(13)以下選項中,能用作數(shù)據(jù)常量的是A)oll5B)0118C)1.5el.5D)

115L

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

x*=(1+x)D)2*x,x+=2

(15)程序段:intx=12;

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

A)123.141593B)123.141593C)12,3.141593D)123.141593

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

A)scanf("%f%f",x,y);B)scant("%f%f",&x,&y);C)scanf(u%lf%leM,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);else

if(x!=10)

printf("%d\n",x);}程序運行時,輸入的值在哪個范圍才會有輸出結(jié)果

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

的整數(shù)

(19)有以下程序

#include<stdio.h>

Main()

{inta=l,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);}程序運行后的輸出結(jié)果是

A)1,2,3B)1,3,2C)1,3,3D)3,2,1

(20)以下程序中的變量已正確定義

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

for(k=l;k<3;k++);printf(*“);程序段的輸出結(jié)果是

A)********B)****c)**D)*

(21)有以下程序

#include<stdio.h>

main()

{char

*s=(“ABC);

do

{printf("%d”;s++;

}while(*s);}注意,字母A的ASCII碼值為65。程序運行后的輸出結(jié)果是

A)5670B)656667C)567D)ABC

(22)設(shè)變量已正確定義,以下不能統(tǒng)計出一行中輸入字符個數(shù)(不包含回車符)的程序段

A)n=0;while((ch=getchar())!='\n')n++;B)n=0;while(getchar()!='\n')n++;

C)for(n=0;getchar()!=?\ny;n++);D)n=0;for(ch=getchar();ch!='\n';n++);

(23)有以下程序

#include<stdio.h>

main()

{intal,a2;charcl,c2;

scanf("%d%c%d%c",&al,&cl,&a2,&c2);

printf("%d,%c,%d,%c",&l,cl,a2,c2);}

若想通過鍵盤輸入,使得al的值為12,a2的是為34,cl的值為字符a,c2的值為字符b,程序

輸出結(jié)果是:12,a,34,b,則正確的輸入格式是(以下代表空格,<CR>代表回車)

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

B)12D)12

aa34

34b<CR>

b<CR>

24)有以下程序

#include<stdio.h>

intf(intxjnty)

{return()y-x)*x);}

main()

{inta=3,b=4/c=5,d;

d=f(f(a,b),f(a,c));

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

A)10B)9C)8D)7

(25)有以下程序

#indude<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,程序運行后的輸出結(jié)果是

A)dB)goC)godD)good

(26)有以下程序

#include<stdio.h>

voidfun(int*a,int*b)

{int*c;

c=a;a=b;b=c;}

main()

{intx=3/y-5z*P=&x,*q=&y;

fun(pzq);printf("%d,%d,”,*p,*q);

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

A)3,5,5,3B)3,5,3,5C)5,3,3,5D)5,3,5,3

(27)有以下程序

#include<stdio.h>

viodf(int*p,int*q);

main()

{intm=l,n=2/*r=&m;

f(r,&n);printf("%d,%d",m,n);}

voidf(int*p,int*q)

{p=p+l;*q=*q+l;}程序運行后輸出的結(jié)果是

A)1,3B)2,3C)1,4D)1,2

(28)以下函數(shù)按每行8個輸出數(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;B)if(i/8==0)continue;

C)if(i%8==0)print("\n");D)if(i%8==0)continue;

(29)若有以下定義intx口O],*pt=x;則對x數(shù)組元素的正確應(yīng)用是

A)*&x[10]B)*(x+3)C)*(pt+10)D)pt+3

30)設(shè)有定義:chars[81];inti=10;,以下不能將一行(不超過80個字符)帶有空格的字符串

真確讀入的語句或語句組是

A)gets(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同卜{"abcd"{"efTgh"{"ijk"};intI;

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

printf("%c”,*a);}程序運行后輸出的結(jié)果是

A)aegiB)dfhkC)abedD)abedefghijk

32)以下選項中正確的語句組是

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

char*s;s=nBOOK!”;

(33)有以下程序

#include<stdio.h>

intfun{intx,inty}

{if(x==y)return(x);

elsereturen((x+y)/2)}

main()

{inta=4,b=5,c=6;

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

A)3B)6C)8D)12

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

A)autoB)registerC)staticD)auto或register

(35)有以下程序

#include<stdio.h>

intb=2;

intfun(int*k)

{b=*k+b;return(b);}

main()

{inta[10]={L2,34,5,6,7,8},l;

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

printf(“\n”)力程序運行后輸出的結(jié)果是

A)10B)8C)10D)10

12102816

36)有以下程序

#include<stdio.h>

#definePT3.5;

#defineS(x)PT*x*x;

mian()

{inta=l,b=2;printf(“%4.1f\n”,S(a+b));}程序運行后輸出的結(jié)果是

A)14.0B)31.5C)7.5D)程序有錯無輸出結(jié)果

37)有以下程序

#include<stdio.h>

structord

{intx,y;}dt[2]={l,23,4);

main()

{structord*p=dt;

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

A)1,2B)2,3C)3,4D)4,1

38)設(shè)有宏定義:include

IsDIV(k,n)((k%n==l)?l:0且變量m已正確定義并賦值,則宏調(diào)用:IsDIV(m,5)&&IsDIV

(m,7)為真時所要表達(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=l,t;

t=(a?2|b);printf("%d\n”,t)}程序運行后的輸出結(jié)果是A)21B)llC)6D)

1

(40)有以下程序

#include<stdio.h>

main()

{EILE*f;

f=fopen("filea.txt"Jw“);

fprintf(f,"abc“);

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

中的內(nèi)容為

A)helloabcB)abcloC)abcD)abchello

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

(1)假設(shè)一個長度為50的數(shù)組(數(shù)組元素的下標(biāo)從。到49)作為棧的存儲空間,棧底指

針bottom指向棧底元素,棧頂指針top指向棧頂元素,如果bottom=49,top=30(數(shù)組下

標(biāo)),則棧中具有【1】個元素。

(2)軟件測試可分為白盒測試和黑盒測試。基本路徑測試屬于【2】測試。

(3)符合結(jié)構(gòu)化原則的三種基本控制結(jié)構(gòu)是:選擇結(jié)構(gòu)、循環(huán)結(jié)構(gòu)和[3L

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

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

(6)表達(dá)式(int)((double)(5/2)+2.5)的值是[6]

(7)若變量x、y已定義為int類型且x的值為99,y的值為9,請將輸出語句printf([7],

x/y);補充完整,使其輸出的計算結(jié)果形式為:x/y=ll

⑻有以下程序

include<stdio.h>

main()

{charcl{c2;scanf(〃&c”{&cl);

while(cl<65||cl>90)

scanf(〃&c”{&cl);

c2=cl+32;

printf("&c,&c\n",cl,c2);}程序運行輸入65回車后,能否輸出結(jié)果、結(jié)束運行(請回答

能或不能)[8L

(9)以下程序運行后的輸出結(jié)果是[9】

#include<stdio.h>

main()

{intk=l,s=0;

do{

if{((k&2)!=0)continue;

s+=k;k++;

}while(k)10);

printf("s=&d/n",s);}

(10)5列程序運行時,若輸入Iabcedl2dfv回車〉輸出結(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'+'A';

a++;putchar(ch);}

printf(〃\n〃);}

(11)有以下程序,程序執(zhí)行后,輸出結(jié)果是[11]

#include<stdio.h>

voidfun(int*a)

{a[0=a[l];]}

main()

{inta[10]={10,9,8,7,6,54,321}/;

for(i=2;i>=0;i-)fun{&a};

for(i=0;i<10;i++)printf(〃&d〃{a);

printf(〃\n〃);

)

(12)請將以下程序中的函數(shù)聲明語句補充完整

#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)以下程序用來判斷指定文件是否能正常打開,請?zhí)羁?/p>

#include<stdio.h>

main()

{FILE*fp;

if(((fp=fopen("test.txt”r"))二二[13]))

printf(“未能打開文件!\n");

else

printf("文件打開成功!\n”);

(14)下列程序的運行結(jié)果為【14】

#include<stdio.h>

#include<string.h>

structA

{inta;charb[10];doublec;};

void

f(struct

A

*t);

main()

{structAa=(1001{,,ZhangDa,,{1098{0);

f(&a);printf("&d{&s{&6{小n”{a.a{a.b{a.c);}

voidf(struct

A

*t)

{strcpy(t->b{z/ChangRongw);}

(15)以下程序把三個NODETYPE型的變量鏈接成一個簡單的鏈表,并在while循環(huán)中輸出鏈

表結(jié)點數(shù)據(jù)域中的數(shù)據(jù),請?zhí)羁?/p>

#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='\O';

p=h;

while(p){printf("&d",p->data);【15];)

)

2008年9月二級C語言筆試真題及答案

(1)一個棧的初始狀態(tài)為空。現(xiàn)將元素1、2、3、4、5、A、B、C、D、E依次入棧,然后

再依次出棧,則元素出棧的順序是()。A)12345ABCDEB)EDCBA54321C)

ABCDE12345D)54321EDCBA

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

A)循環(huán)隊列有隊頭和隊尾兩個指針,因此,循環(huán)隊列是非線性結(jié)構(gòu)

B)在循環(huán)隊列中,只需要隊頭指針就能反映隊列中元素的動態(tài)變化情況

C)在循環(huán)隊列中,只需要隊尾指針就能反映隊列中元素的動態(tài)變化情況

D)循環(huán)隊列中元素的個數(shù)是由隊頭指針和隊尾指針共同決定

3)在長度為n的有序線性表中進(jìn)行二分查找,最壞情況下需要比較的次數(shù)是()。

A)0(n)B)0(n2)C)O(log2n)D)O(nlog2n)

4)下列敘述中正確的是()。

A)順序存儲結(jié)構(gòu)的存儲一定是連續(xù)的,鏈?zhǔn)酱鎯Y(jié)構(gòu)的存儲空間不一定是連續(xù)的

B)順序存儲結(jié)構(gòu)只針對線性結(jié)構(gòu),鏈?zhǔn)酱鎯Y(jié)構(gòu)只針對非線性結(jié)構(gòu)

C)順序存儲結(jié)構(gòu)能存儲有序表,鏈?zhǔn)酱鎯Y(jié)構(gòu)不能存儲有序表D)鏈?zhǔn)酱鎯Y(jié)構(gòu)比順序

存儲結(jié)構(gòu)節(jié)省存儲空間

5)數(shù)據(jù)流圖中帶有箭頭的線段表示的是()。

A)控制流B)事件驅(qū)動C)模塊調(diào)用D)數(shù)據(jù)流

6)在軟件開發(fā)中,需求分析階段可以使用的工具是()o

A)N-S圖B)DFD圖C)PAD圖D)程序流程圖

7)在面向?qū)ο蠓椒ㄖ校粚儆凇皩ο蟆被咎攸c的是()。

A)一致性B)分類性C)多態(tài)性D)標(biāo)識唯一性

(8)一間宿舍可住多個學(xué)生,則實體宿舍和學(xué)生之間的聯(lián)系是(

A)一對一B)一對多C)多對D)多對多

(9)在數(shù)據(jù)管理技術(shù)發(fā)展的三個階段中,數(shù)據(jù)共享最好的是()。

A)人工管理階段B)文件系統(tǒng)階段C)數(shù)據(jù)庫系統(tǒng)階段D)三個階段相同

(10)有三個關(guān)系R、S和T如下:

RST

ABBCABC

m113m13

n235

由關(guān)系R和S通過運算得到關(guān)系T,則所使用的運算為()。A)笛卡爾積B)交C)

并D)自然連接

(11)以下敘述中正確的是(

A)C程序的基本組成單位是語句B)C程序中的每一行只能寫一條語句

C)簡單C語句必須以分號結(jié)束D)C語句必須在一行內(nèi)寫完

12)計算機(jī)能直接執(zhí)行的程序是()。A)源程序B)目標(biāo)程序C)匯編程序D)可執(zhí)行

程序

13)以下選項中不能作為C語言合法常量的是()。A)'cd'B)0.1e+6C)"\a"D)

'\011'

14)以下選項中正確的定義語句是()o

A)doublea;b;B)doublea=b=7;C)doublea=7,b=7;D)double,a,b;

15)以下不能正確表示代數(shù)式2abcd的C語言表達(dá)式是()。

A)2*a*b/c/dB)a*b/c/d*2C)a/c/d*b*2D)2*a*b/c*d

16)C源程序中不能表示的數(shù)制是()。A)二進(jìn)制B)八進(jìn)制C)十進(jìn)制D)十六進(jìn)

17)若有表達(dá)式(w)?(--x):(++y),則其中與w等價的表達(dá)式是()?A)w==lB)w==0C)w!=l

D)w!=0

18)執(zhí)行以下程序段后,w的值為()。

intw='A',x=14,y=15;

w=((x11y)&&(w<'a'));A)-1B)NULLC)ID)0

19)若變量已正確定義為int型,要通過語句scanf("%d,%d,%d",&a,&b,&c);給a賦值

1、給b賦值2、給c賦值3,以下輸入形式中錯誤的是(d代表一個空格符)()。

A)ddd1,2,3(回車〉B)1d2d3c回車〉C)l,ddd2,ddd3c回車〉D)1,2,3〈回

車〉

(20)有以下程序段

inta,b,c;

a=10;b=50;c=30;

if(a>b)a=b,b=c;c=a;

printf("a=%db=%dc=%d\nw,a,b,c);程序的輸出結(jié)果是()。

A)a=10b=50c=10B)a=10b=50c=30C)a=10b=30c=10D)a=50b=30c=50

(21)若有定義語句:intm[]={5,4,321},i=4;,則下面對m數(shù)組元素的引用中錯誤的是()。

A)m[-i]B)m[2*2]C)m[m[O]]D)m[m[i]]

(22)下面的函數(shù)調(diào)用語句中func函數(shù)的實參個數(shù)是()。

func(f2(vl,v2),(v3,v4,v5),(v6,max(v7,v8)));A)3B)4C)5D)8

(23)若有定義語句:doublex[5]={1.0,2.0,3.0,4.0,5.0},*p=x;則錯誤引用x數(shù)組元素的是()。

A)*pB)x[5]C)*(p+l)D)*x

(24)若有定義語句:chars口0]="1234567\0\0";,則strlen(s)的值是()。A)7B)8C)9D)

10

(25)以下敘述中錯誤的是(

A)用戶定義的函數(shù)中可以沒有return語句

B)用戶定義的函數(shù)中可以有多個return語句,以便可以調(diào)用一次返回多個函數(shù)值

C)用戶定義的函數(shù)中若沒有return語句,則應(yīng)當(dāng)定義函數(shù)為void類型D)函數(shù)的return

語句中可以沒有表達(dá)式

(26)以下關(guān)于宏的敘述中正確的是()。

A)宏名必須用大寫字母表示B)宏定義必須位于源程序中所有語句之前

O宏替換沒有數(shù)據(jù)類型限制D)宏調(diào)用比函數(shù)調(diào)用耗費時間

*****(27)有以下程序

#include<stdio.h>

main()

{inti,j;

for(i=3;i>=l;i-)

{for(j=l;j<=2;j++)printf("%d“,i+j);

printfCAn");

}}程序的運行結(jié)果是()o

A)234B)432345543C)23D)4534344523

(28)有以下程序

#include<stdio.h>

main()

{intx=l,y=2,z=3;

if(x>y)

if(y<z)printf("%d"z++z);

elseprintf("%d",++y);

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

}程序的運行結(jié)果是()o

A)331B)41C)2D)1

(29)有以下程序

#include<stdio.h>

main()

{inti=5;

do

{if(i%3=l)

if(i%5==2)

{print"'*%%',i);break;}

i++;

}while(i!=O);

printf("\n");

}程序的運行結(jié)果是(),A)*7B)*3*50*5D)*2*6

(30)有以下程序

#include<stdio.h>

intfun(intajntb)

{if(b==0)returna;

elsereturn(fun(-az-b));

)

main()

{printf("%d\n",fun(4,2));}程序的運行結(jié)果是()。A)1B)203D)4

(31)有以下程序

#include<stdio.h>

#include<stdlib.h>

intfun(intn)

{int*p;

p=(int*)malloc(sizeof(int));

*p=n;return*p;

)

main()

{inta;

a=fun(10);printf("%d\n",a+fun(10));

}程序的運行結(jié)果是()oA)OB)IOC)20D)出錯

(32)有以下程序

#include<stdio.h>

voidfun(inta,intb)

{intt;

t=a;a=b;b=t;

)

main()

{intc[10]={l,2,3,4,5,6,7,8,9,0),i;

for(i=0;i<10;i+=2)fun(c[i],c[i+l]);

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

printf("\n");

}程序的運行結(jié)果是()o

A)1,2,3,4,56,7,8,9,0,B)2,1,4,3,6,5,8,7,0,9,C)0,9,8,7,6,5,4,3,2,1,D)0,1,2,3,4,5,6,7,8,9,

(33)有以下程序

#include<stdio.h>

structst

{intx,y;)data[2]={l,10,2,20};

main()

{structst*p=data;

printf("%dz",p->y);printf("%d\n"z(++p)->x);

}程序的運行結(jié)果是()。A)10,1B)20,1010,2D)20,2

(34)有以下程序

#include<stdio.h>

voidfun(inta[],intn)

{inti,t;

for(i=0;i<n/2;i++){t=a[i];a[i]=a[n-l-i];a[n-l-i]=t;}

)

main()

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

fun(k,5);

for(i=2;i<8;i++)printf("%d",k[i]);

printf("\n");

}程序的運行結(jié)果是()oA)345678B)876543C)1098765D)321678

(35)有以下程序

#include<stdio.h>

#defineN4

voidfun(inta[][N],intb[])

{inti;

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

)

main()

{intx[][N]={{l,2,3),{4),{5,6,7,8),{9,10}},y[N],i;

fun(x,y);

for(i=0;i<N;i++)printf(“%dNy[i]);

printf(H\n");

}程序的運行結(jié)果是()oA)1,234B)1,07,0,C)1,459,D)3,4,8,10,

(36)有以下程序

#include<stdio.h>

intfun(int(*s)[4],intn,intk)

{intm,i;

m=s[0][k];

for(i=l;i<n;i++)if(s[i][k]>m)m=s[i][k];

returnm;

)

main()

{inta⑷⑷={{1,2,3,4),{11,12,13,14},{21,22,23,24},{31,32,33,34}};

printf("%d\n",fun(aAO));

}程序的運行結(jié)果是()oA)4B)34031D)32

(37)有以下程序

#include<stdio.h>

main()

{structSTU{charname[9];charsex;doublescore[2];};

structSTUa={"Zhao";m'z85.0,90.0),b={"Qian";f'/95.0,92.0);b=a;

printf("%s/%c/%2.0f,%2.0f\n"http://b.sex,b.score[0],b.score[l]);

}程序的運行結(jié)果是(

)oA)Qian,f,95,92B)Qian,m,85,90C)Zhao,f,95,92D)Zhao,mz85z90

(38)假定已建立以下鏈表結(jié)構(gòu),且指針p和q已指向如圖所示的結(jié)點:

headabc

datanext

tPtq

則以下選項中可將q所指結(jié)點從鏈表中刪除并釋放該結(jié)點的語句組是()。

A)(*p).next=(*q).next;free(p);B)p=q->next;free(q);

C)p=q;free(q);D)p->next=q->next;free(q);

(39)有以下程序

#include<stdio.h>

main()

{chara=4;

,,

printf("%d\n/a=a?l);

}程序的運行結(jié)果是()oA)40B)1608D)4

(40)有以下程序

#include<stdio.h>

main()

{FILE*pf;

char*sl="China"/s2=,,Beijing";

pf=fopen("abc.dat"z"wb+");

fwrite(s2,7,lzpf);

rewind(pf);

fwrite(slz5,l/Pf);

fclose(pf);

}以上程序執(zhí)行后abc.dat文件的內(nèi)容是()。A)ChinaB)ChinangC)ChinaBeijingD)

BeijingChina

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

1)對下列二叉樹進(jìn)行中序遍歷的結(jié)果【1】o

A

BC

DEF

XYZ

(2)按照軟件測試的一般步驟,集成測試應(yīng)在【2】測試之后進(jìn)行。

(3)軟件工程三要素包括方法、工具和過程,其中,【3】支持軟件開發(fā)的各個環(huán)節(jié)的控

制和管理。

(4)數(shù)據(jù)庫設(shè)計包括概念設(shè)計、【4】和物理設(shè)計。

(5)在二維表中,元組的【5】不能再分成更小的數(shù)據(jù)項。

(6)設(shè)變量a和b已正確定義并賦初值。請寫出與a-=a+b等價的賦值表達(dá)式【6】。

(7)若整型變量a和b中的值分別為7和9,要求按以下格式輸出a和b的值:

a=7

b=9

請完成輸出語句:printf("[7],a,b);。

(8)以下程序的輸出結(jié)果是[8】o

#include<stdio.h>

main()

{inti,j,sum;

for(i=3;i>=l;i-)

{sum=O;

for(j=l;j<=i;j++)sum+=i*j;}

printf("%d\n,sum);}

(9)以下程序的輸出結(jié)果是[9】o

#include<stdio.h>

main()

{intj,a[={135,7,9,11,73,15},*p=a+5;

for(j=3;j;j--)

{switch(j)

{case1:

case2:printf("%d",*p++);break;

case3:printf("%d"/*(-p));

}})

(10)以下程序的輸出結(jié)果是[10].

#include<stdio.h>

#defineN5

intfun(int*s,inta,intn)

{intj;

*s=a;j=n;

while(a!=s[j])j-;

returnj;

)

main()

{ints[N+l];intk;

for(k=l;k<=N;k++)s[k]=k+l;

printf("%d\n",fun(sAN));}

(11)以下程序的輸出結(jié)果是

溫馨提示

  • 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)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論