C語言的應用範圍廣泛,具備很強的資料處理能力,不僅僅是在軟體開發上,而且各類科研都需要用到C語言,適於編寫系統軟體,三維,二維圖形和動畫,具體應用比如微控制器以及嵌入式系統開發。下面是小編收集的關於全國計算機二級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;=’