2017下半年全國計算機二級C語言檢測試題

學識都 人氣:2.58W

C語言的應用範圍廣泛,具備很強的數據處理能力,不僅僅是在軟件開發上,而且各類科研都需要用到C語言,適於編寫系統軟件,三維,二維圖形和動畫,具體應用比如單片機以及嵌入式系統開發。下面是小編收集的關於全國計算機二級C語言檢測試題,希望大家認真閱讀!

2017下半年全國計算機二級C語言檢測試題

一、選擇題

1). 在軟件設計中,不屬於過程設計工具的是( )

(過程設計語言)

C.N-S圖

正確答案:D

答案解析:DFD(數據流圖Data-Flow-Diagram)是描述數據處理過程的工具,是需求理解的邏輯模型的圖形表示。它直接支持系統功能建模。在軟件詳細設計的過程階段,要對每個模塊規定的功能以及算法的設計給出適當的算法描述。常見的過程設計工具有:圖形工具:程序流程圖,N-S,PAD,HIPO;表格工具:判定表;語言工具:PDL(僞碼)。

2). 數據結構中,與所使用的計算機無關的是數據的( )。

A.存儲結構

B.物理結構

C.邏輯結構

D.線性結構

正確答案:C

答案解析:數據的邏輯結構反映的是數據元素之間的邏輯關係,與使用的計算機無關。

3). 設有定義: int x=2; 以下表達式中,值不爲6的是( )

A.2*x, x+=2

B.x++,2*x

C.x*=(1+x)

D.x*=x+1

正確答案:A

答案解析:本題考查逗號表達式。逗號表達式的求解過程是:先求解表達式1,再求解表達式2,整個逗號表達式的值是表達式2的值,因此,選項A中值爲4;選項B中,值爲6。選項C中x*=x+1 等價於x=x*(x+1),所以等於6;選項D與選項C等價,結果也爲6。

4). 在長度爲64的有序線性表中進行順序查找,最壞情況下需要比較的次數爲( )

A.63

B.64

C.6

D.7

正確答案:B

答案解析:順序查找又稱順序搜索。順序查找一般是指在線性表中查找指定的元素,其基本方法是:從線性表的第一元素開始,依次將線性表中的元素與被查找的元素進行比較,若相等則表示找到(即查找成功),若線性表中所有元素都與被查元素進行了比較但都不相等,則表示線性表中沒有要找的元素(即查找失敗)。如果線性表中的第一個元素就是要查找的元素,則只需要做一次比較就查找成功;但如果要查找的.元素是線性表中的最後一個元素,或者要查找元素不在線性表中,則需要與線性表中所有元素進行比較,這是順序查找的最壞情況,比較次數爲線性表的長度。

5). 下列特徵中不是面向對象方法的主要特徵的是( )。

A.多態性

B.標識惟一性

C.封裝性

D.耦合性

正確答案:D

答案解析:面向對象設計方法與面向過程設計方法有本質的不同,其基本原理是:使用現實世界的概念抽象地思考問題從而自然地解決問題。其特點包括:標識惟一性、多態性、封裝性、模塊獨立性、繼承和多態性好。

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

請將每一個空的正確答案寫在答題卡【1】至【15】序號的橫線上,答在試卷上不得分。

(1)假設一個長度爲50的數組(數組元素的下標從0到49)作爲棧的存儲空間,棧底指針bottom指向棧底元素,棧頂指針top指向棧頂元素,如果bottom=49,top=30(數組下標),則棧中具有【1】個元素。

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

(3)符合結構化原則的三種基本控制結構是:選擇結構、循環結構和【3】。

(4)數據庫系統的核心是 【4】

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

(6)表達式(int)((double)(5/2)+2.5)的值是【6】

(7)若變量x、y已定義爲int類型且x的值爲99,y的值爲9,請將輸出語句printf(【7】,x/y);補充完整,使其輸出的計算結果形式爲:x/y=11

(8)有以下程序

#include

main( )

{

char c1,c2;

scanf(“&c”,&c1);

while(c1<65||c1>90)

scanf(“&c”,&c1);

c2=c1+32;

printf(“&c, &cn”,c1,c2);

}

程序運行輸入65回車後,能否輸出結果、結束運行(請回答能或不能)【8】。

(9)以下程序運行後的輸出結果是【9】

#include

main( )

{int k=1,s=0;

do{

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

s+=k;k++;

}while(k)10);

printf(“s=&d/n”,s);

}

(10)下列程序運行時,若輸入labced12df<回車>輸出結果爲【10】

#include

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)有以下程序,程序執行後,輸出結果是【11】

#include

void fun (int *a)

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

main()

{int a[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)請將以下程序中的函數聲明語句補充完整

#include

int【12】

;

main( )

{int x,y,(*p)();

p=max;

printf(“&dn”,&x,&y);

}

Int max(int a,int b)

{return (a>b/a:b);}

(13)以下程序用來判斷指定文件是否能正常打開,請填空

#include

main( )

{FILE *fp;

if (((fp=fopen(“”,”r”))==【13】))

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

else

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

(14)下列程序的運行結果爲【14】

#include

#include

struct A

{int a;char b[10];double

c;};

void

f (struct

A

*t);

main()

{struct A a=(1001,”ZhangDa”,1098,0);

f(&a);printf(“&d,&s,&6,ifn”,a.a,a.b,a.c);

}

void f(struct

A

*t)

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

}

(15)以下程序把三個NODETYPE型的變量鏈接成一個簡單的鏈表,並在while循環中輸出鏈表結點數據域中的數據,請填空

#include

struct node

{int data; struct node *next;};

typedef struct node NODETYPE;

main()

{NODETYPE a,b,c,*h,*p;

a.

data=10;=20;=30;h=&a;

b.

next=&b;=&c;=’