1. 首頁
  2. 筆試

c語言筆試題目及答案

c語言筆試題目及答案

C語言是一門通用計算機程式語言,應用廣泛。C語言的設計目標是提供一種能以簡易的方式編譯、處理低階儲存器、產生少量的機器碼以及不需要任何執行環境支援便能執行的程式語言。下面是c語言筆試題目及答案,請參考。

c語言筆試題目及答案

一、選擇題((1)~(10)每小題2分,(11)~(50)每小題1分,共60分)

下列各題A)、B)、C)、D)四個選項中,只有一個選項是正確的,請將正確的選

項塗寫在答題卡相應位置上,答在試卷上不得分。

(1)資料的儲存結構是指________。

A)儲存在外存中的資料 B)資料所佔的儲存空間量

C)資料在計算機中的順序儲存方式 D)資料的邏輯結構在計算機中的表示

答案:

D

評析:資料的邏輯結構在計算機儲存空間中的存放形式形式稱為資料的儲存結構(也稱資料的物理結構)。

(2)下列關於棧的描述中錯誤的是________。

A)棧是先進後出的線性表

B)棧只能順序儲存

C)棧具有記憶作用

D)對棧的插入與刪除操作中,不需要改變棧底指標

答案:B

評析:棧是一種特殊的線性表,又稱先進後出表(FILO—First In Last Out)。

(3)對於長度為n的線性表,在最壞情況下,下列各排序法所對應的比較次數中正確的是

________。

A)氣泡排序為n2 B)氣泡排序為n

C)快速排序為n D)快速排序為n(n一1)/2

答案:D

評析:假設線性表的長度為n,則在最壞情況下,氣泡排序需要經過n/2遍的從前往後掃描和n/2遍的從後往前掃描,需要比較次數為n(n-1)/2。快速排序法的最壞情況比較次數也是n(n-1)/2。

(4)對長度為n的線性表進行順序查詢,在最壞情況下所需要的比較次數為________。

A)log2n B)n/2 C)n D)n+l

答案:C

評析:順序查詢過程中,如果被查詢的元素是線性表中的最後一個元素,或者元素不線上性表中,則需要與線性表中所有的元素進行比較。對長度為n的線性表進行順序查詢,在最壞情況下需要比較n次。

(5)下列對於線性連結串列的描述中正確的是________。

A)儲存空間不一定是連續,且各元素的儲存順序是任意的

B)儲存空間不一定是連續,且前件元素一定儲存在後件元素的前面

C)儲存空間必須連續,且前件元素一定儲存在後件元素的前面

D)儲存空間必須連續,且各元素的儲存順序是任意的

答案:A

評析:在鏈式儲存結構中,儲存資料結構的儲存空間可以不連續,各資料結點的儲存順序與資料元素之間的邏輯關係可以不一致,而資料元素之間的邏輯關係是由指標域來確定的。

(6)下列對於軟體測試的描述中正確的是________。

A)軟體測試的目的是證明程式是否正確

B)軟體測試的目的是使程式執行結果正確

C)軟體測試的目的是儘可能多地發現程式中的錯誤

D)軟體測試的目的是使程式符合結構化原則

答案:C

評析:關於軟體測試的目的,Grenford J.Myers再《The Art of Software Testing》一書中給出了深刻的闡述,整體來說,軟體測試的目的就是儘可能多地發現程式中的錯誤。

(7)為了使模組儘可能獨立,要求________。

A)模組的內聚程度要儘量高,且各模組間的耦合程度要儘量強

B)模組的內聚程度要儘量高,且各模組間的耦合程度要儘量弱

C)模組的內聚程度要儘量低,且各模組間的耦合程度要儘量弱

D)模組的內聚程度要儘量低,且各模組間的耦合程度要儘量強

答案:B

評析:模組獨立性是指每個模組只完成系統要求的獨立的子功能,並且與其他模組的聯絡最少且介面簡單。軟體設計,應儘量做到高內聚,低耦合,有利於提高模組的獨立性。

(8)下列描述中正確的是________。

A)程式就是軟體

B)軟體開發不受計算機系統的限制

C)軟體既是邏輯實體,又是物理實體

D)軟體是程式、資料與相關文件的集合

答案:D

評析:計算機軟體是計算機系統中與硬體相互依存的另一部分,是包括程式、資料及相關文件的完整集合。

(9)資料獨立性是資料庫技術的重要特點之一,所謂資料獨立性是指________。

A)資料與程式獨立存放

B)不同的資料被存放在不同的檔案中

C)不同的資料只能被對應的應用程式所使用

D)以上三種說法都不對

答案:D

評析:資料獨立性是資料與程式間的互不依賴性,即資料庫中資料獨立於應用程式而不依賴於應用程式。也就是說,資料的邏輯結構、儲存結構與存取方式的改變不會影響應用程式。選項A、B、C三種說法都是錯誤的。

(10)用樹形結構表示實體之間聯絡的模型是________。

A)關係模型 B)網狀模型 C)層次模型 D)以上三個都是

答案:C

評析:層次模型是最早發展起來的資料庫模型,它的基本結構是樹形結構。

(11)演算法具有五個特性,以下選項中不屬於演算法特性的是________。

A)有窮性 B)簡潔性 C)可行性 D)確定性

答案:B

評析:有窮性、確定性、有零個或多個輸入、有一個或多個輸出、有效性是演算法的基本特性。

(12)以下選項中可作為C語言合法常量的是________。

A)-80. B)-080 C)-8e1.0 D)-80.0e

答案:A

評析:c語言的常量分為整型常量、實型常量和字元型常量。選項A屬於實型常量中的十進位制小數形式的表示法,是合法的。

(13)以下敘述中正確的是________。

A)用C程式實現的演算法必須要有輸入和輸出操作

B)用C程式實現的演算法可以沒有輸出但必須要輸入

C)用C程式實現的演算法可以沒有輸入但必須要有輸出

D)用C程式實現的演算法可以既沒有輸入也沒有輸出

答案:C

評析:演算法的特性中包括“有零個或多個輸入”及“有一個或多個輸出”這兩個特性。一個演算法得到的結果就是演算法的輸出,沒有輸出的演算法是沒有意義的,所以一個演算法必須至少有一個輸出。

(14)以下不能定義為使用者識別符號的是________。

A)Main B)_0 C)_int D)sizeof

答案:D

評析:C語言規定識別符號只能由字母、數字和下劃線三種符號組成,而且第一個字元必須是字母或下劃線。注意:大寫字母和小寫字母被認為是兩個不同的`字元。A中Main與主i函式名main不同。

(15)以下選項中不能作為合法常量的是________。

A)1.234e04 B)1.234e0.4 C)1.234e+4 D)1.234e0

答案:B

評析:指數形式的實型常量要求字每e(或E)之前必需有數字,且e後面的指數必須為整數,所以本題中選項B非法。

(16)數字字元0的ASCII值為48,若有以下程式

main()

{char a=”1″,b=”2″;

printf(“%c,”,b++);

printf(“%d ”,b-a);

)

程式執行後的輸出結果是________。

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

答案:C

評析l執行語句“printf(“%c,ll,b++);”後,b的值變成字元3,執行“printf(“%d ”,b-a);”,即‘3’-‘1’。

(17)有以下程式

main( )

{

int m=12, n=34;

printf(“%d%d”,m++,++n);

printf(“%d%d ”,n++,++m);

}

程式執行後的輸出結果是________。

A)12353514 B)12353513 C)12343514 D)12343513

答案:A

評析:執行“printf(“%d%d”m++,++n);”後,輸出的是m和n+l的值1235,接著執行

“printf(“%d%d\n”,n++,++m);”輸出n和m+l的值3514。

(18)有定義語句:int b;char c[10】;,則正確的輸入語句是________。

A) scanf("%d%s",&b,&C); B) scanf("%d%s",&b,C);

C) scanf("%d%s",b,C); D) scanf("%d%s",b,&C);

答案:B

評析:scanf函式中的“格式控制”後面應當是地址,而不是變數名。對於變數,透過地址運算子“&”求出記憶體中的地址;對於陣列c[10],陣列名c即為陣列在記憶體中的地址。

(19)有以下程式

main()

{int m,n,p;

scanf(“m=%dn=%dp=%d”,&m,&n,&p);

printf(“%d%d%d\n”,m,n,p);

}

若想從鍵盤上輸入資料,使變數m中的值為123,n中的值為456,p中的值為789,

則正確的輸入是________。

A) m。123n=456p=789 B) m=123 n=456 p=789

C) m=123,n=456,p=789 D) 123 456 789

答案:A

評析:根據本題的資料輸入形式“scanf(“m=%dn=%dp=%d”&m,&n,&p);”說明在輸入資料時,必須輸入“m=”、“n=”、“p=”字元,且中間不能含有空格。

(20)有以下程式

main()

{ int a,b,d=25;

a=d/10%9;

b=a&&(-1);

printf(”%d,%d\n”,a,b);

}

程式執行後的輸出結果是________。

A)6,l B)2,l C)6,0 D)2,0

答案:B

評析:本題中“a=d/10%9;”的值為25/10%9=2; “b=a&&(-1);”為2&&(-1)=1(注意:-1表示真,只有O才表示假),所以a,b的值分別為2,1。

(21)有以下程式

main()

{

int i=1 j=2,k=3;

if(i++==1&&(++j==3||k++==3))

printf(“%d%d%d\n”,i,j,k);

}

程式執行後的輸出結果是________。

A)l 2 3 B)2 34 C) 2 2 3. D)2 3 3

答案:D

評析:執行“i++==1&&(++j==3‖k++==3)”時,表示式“i++==1”嗨值為真,其值為1,表示式“++j=3”的值為真,根據短路原理,右邊的表示式“k++==3”不再進行運算。括號中表達的值為l,作與運算後整個表示式的值也為l,輸出i.j,k時,由於未執行過k,所以它們的值分別為2,3,3。

(22)若整型變數a、b、c、d中的值依次為:1、4、3、2。則條件表示式a<b?a:c<d?c:d的值是________。

A)l B)2 C)3 D)4

答案:A

評析:條件表示式的一般形式為:表示式17表示式2:表示式3

本題先求的是a<b的值,為真,所以整個表示式“a<b?a:c<d?c:d”的值為a的值1。

(23)有以下程式

main( )

{

int p[8]={11,12,13,14,15,16,17,18},i=O,j=0;

while(i++<7)if p[i]%2)j+-=p[i];

printf(“%d\n”,j);

}

程式執行後的輸出結果是________。

A)42 B)45 C)56 D)60

答案:B

評析:本程式的作用是求除p[O]外的其它奇數的和。

(24)有以下程式

main()

{

char a[7]= “a0\OaO\0”; int i,j;

i=sizeof(a);j=strlen(a);

printf(“%d%d\n”,i,j);

)

程式執行後的輸出結果是________。

A)2 2 B)76 C)7 2 D)6 2

答案:C

評析:c語言中以‘\0’作為字串的結束符,且strlen()函式計算的是‘\0’字元前的所有字元的個數。陣列定義以後系統就為其分配相應大小的記憶體空間,而不論其中有沒有內容。

(25)以下能正確定義一維陣列的選項是________。

A)int a[5]={0,1,2,3,4,5; B)char a[]={0,1,2,3,4,5};

C)char a={’A’,’B’,’C’}; D)int a[5]=”0123″;

答案:B

評析:選項A中定義的是5個數組元素,但賦值的時候賦的是6個元素,所以出錯;選項c不符合陣列定義形式,陣列名後應加上“[]”;選項D的型別說明符錯誤,如果用char定義就對了;選項B中的0,1,2,3,4,5分別表示對應字元的ASCII碼,所以選項B是正確的。

(26)有以下程式

int fl(int x,int y){return x>y?x:y;}

int f2(int x,int y){return x>y?y:x;}

main()

{

int a=4,b=3,c=5,d=2,e,f,g;

e=f2(f1(a,b),f1(c,d));f=fl(f2(a,b),f2(c,d));

g=a+b+c+d-e-f;

printf(“%d,%d,%d\n”,e,f,g);

)

程式執行後的輸出結果是________。

A)4,3,7 B)3,4,7 C)5,2,7 D)2,5,7

答案:A

評析:函式n的功能是返回兩個數中比較大的值,f2的功能是返回兩個數中比較小的值。

(27)已有定義:char a[]=”xyz”,b[]={’x’,’y’,’z};,以下敘述中正確的是________。

A)陣列a和b的長度相同 B)a陣列長度小於b陣列長度

C)a陣列長度大於b陣列長度 D)上述說法都不對

答案:C

評析:c語言規定‘\0’為字串結束標誌。所以“char a[]=“xyz””的陣列長度為4,而“b[]={‘x’,‘y’,‘z’};”的陣列長度為3,陣列長度與strlen函式所求的長度不同,本題是指陣列佔記憶體空間的大小。

(28)有以下程式

Void f(int *x, int *y)

{

int t;

t= *x; *x=*y;’*y=t;

)

main( )

{

int a[8]={1,2,3,4,5,6,7,8},i,*p,*q;

p=a;q=&a[7];

while(p<q)

{f(p,q); p++; q–;} 。

for(i=0;i<3;i++) printf(“%d”,a[1][i]);

}

程式執行後的輸出結果是________。

A)8,2,3,4,5,6,7,1, B)5,6,7,8,1,2,3,4.

C)1,2,3,4,5,6,7,8, D)8,7,6,5,4,3,2,l,

答案:D

評析;本程式中函式f的作用是交換指標變數x和y所指向的儲存單元的值。

(29)有以下程式

main()

{

im a[3][3],*p,i;

p=&a[0][o];

for(i=0;j<9;i++) p[i]=I;

for(i=0;j<3;i++)printf(“%d”,a[1][i]);

)

程式執行後的輸出結果是________。

A)012 B)123 C)234 D)345

答案:D

評析:本題賦值後,a的陣列元素的值分別為a[01[0]=0,a[0][1]=1,a[0][2]=2,a[1][0]=3,a[1][1]=4,a[1][2]=5,a[2][0]=6,a[2][1]=7,a[2][2]=8,故本題輸出的值為345。

(30)以下敘述中錯誤的是________。

A)對於double型別陣列,不可以直接用陣列名對陣列進行整體輸入或輸出

B)陣列名代表的是陣列所佔儲存區的首地址,其值不可改變

C)當程式執行中,陣列元素的下標超出所定義的下標範圍時,系統將給出“下標越

界”的出錯資訊

D)可以透過賦初值的方式確定陣列元素的個數

答案:C

評析:在c語言中,如果出現下標越界的情況,系統不管在編譯還是執行時都不會給出“下標越界”的錯誤提示。

(31)有以下程式

#define N20

fun(int a[],int n,int m)

{ int i,j;

for(i=m;i>=n;i–)a[i+1]=a[i];

}

main()

{

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

fun(a,2,9);

for(i=O;i<5;i++) printf(“%d”,a[i]);

}

程式執行後的輸出結果是________。

A)10234 B)12344 C)12334 D)12234

答案:C

評析:本題函式fun的作用是將指定的陣列元素(從下標n到下標m)向後移一位。由函式呼叫“fun(a,2,9);”可知,函式fun用於將a[2]到a[9]的各元素依次向後移一位,移完後,a陣列中各元素的值分別為1,2,3,3,4,5,6,7,8,9,10,故輸出的前5個數組元素為12334。

(32)有以下程式

main()

{

int a[3][2]={0},(*ptr)[2],i,j;

for(i=0;i<2;i++) {ptr=a+i; scanf(“%d”,ptr); ptr++;}

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

{ for(i=0;j<2;j++) printf(“%2d”,a[i][j]);

printf(“\n”);

}

}

若執行時輸入:1 2 3<回車>,則輸出結果是________。

A)產生錯誤資訊

B)l0 C)l 2 D)l 0

2 O 3 0 2 0

0 0 0 O 3 0

答案:B

評析:二維陣列a,透過a[3][2]={0}將陣列中的各個元素初始化為0,指標變數ptr,指向包含2個元素的一維陣列。a[0][0]:l,a[1][0]=2,故本題的輸出選B。

(33)有以下程式

prt(int *m, int n)

{ int i;

for(i=O;i<n;i++) m[i]++;

)

main()

{

int a[]={ 1,2,3,4,5 },i;

prt(a,5);

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

printf(“%d,”,a[i]);

程式執行後的輸出結果是________。

A)l,2,3,4,5, B)2,3,4,5,6, C)3,4,5,6,7, D)2,3,4,5,1,

答案:B

評析:用陣列名作函式實參時,不是把陣列的值傳遞給形參,而是把實引數組的起始地址傳遞給形引數組,這樣兩個陣列就共同佔用同一段記憶體單元。

(34)有以下程式

main()

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

for(p=a;p<a+10;p++)printf(“%d,”,*p);

}

程式執行後的輸出結果是________。

A)l,2,3,4,5,6,7,8,9,0, B)2,3,4,5,6,7,8,9,10,1,

C)0,1,2,3,4,5,6,7,8,9, D)l,l,1,l,l,l,l,l,l,l,

答案:A

評析:c語言規定陣列變數名代表陣列的首地址,即第0號元素的地址。本題將a陣列中的值全部輸出,即為l,2,3,4,5,6,7,8,9,0,。

(35)有以下程式

#define P 3

void F(int x){return(P*x*x);}

main()

{printf(“%d\n”,F(3+5));}

程式執行後的輸出結果是________。

A)192 B)29 C)25 D)編譯出錯

答案:D

評析:return語句用於從被調函式帶回一個函式值。void關鍵字表示“無型別”,即不需要從被調函式中帶回函式值,所以不需要return語句,故編譯時出錯。

(36)有以下程式

main()

{int c=35;printf(“%d\n”,c&C);}

程式執行後的輸出結果是________。

A)0 B)70 C)35 D)1

答案:C

評析:按位“與”時,1&1=1,其他都等O。因為本題中相與的兩個值相等,即對應位上的二進位制值相等,所以“與”的結果也即為其值本身。

(37)以下敘述中正確的是________。

A)預處理命令列必須位於原始檔的開頭

B)在原始檔的一行上可以有多條預處理命令

C)宏名必須用大寫字母表示

D)宏替換不佔用程式的執行時間

答案:D

評析:通常,預處理命令位於原始檔的開頭,也可以寫在函式與函式之間;不能在一行上寫多條預處理命令:宏名一般習慣用大寫字母表示,以便與變數名相區別,但這並非規定,也可用小寫字母。

(38)若有以下說明和定義

union dt

{int a;har b;ouble c;}data;

以下敘述中錯誤的是________。

A)data的每個成員起始地址都相同

B)變數data所佔的記憶體位元組數與成員c所佔位元組數相等

C)程式段:data.a=5;pintf(“%f ”,data.C);輸出結果為5.000000

D)data可以作為函式的實參

答案:C

評析:union是表示共用體的關鍵字,成員a,b,c共佔用同一個記憶體空間,data的每個成員起始地址都相同;共用體變數所佔的記憶體長度等於最長的成員的長度,故變數’data所佔的記憶體位元組數與成員c所佔位元組數相等;執行“data.a=5;printf(“%f ”,data.C);”printf函式只是將記憶體中的資料以不同的型別輸出,而不能將記憶體中的整型資料自動轉換為等值的浮點數,故C是錯誤的。

(39)以下語句或語句組中,能正確進行字串賦值的是________。

A)char*sp;*sp=”right!”; B)char s[lO];s=”right! “;

C)char s[10];*s=”right! “; D)char*sp=”right! “;

答案:D

評析:選項A定義了字元型的指標變數sp,則*sp儲存的是第一個字元,而給它賦的是字串,故錯;

選項B表示代表陣列的首地址,而題中給它賦的是字串,所以錯誤;

選項c定義了一個字元型的陣列s[10],再透過+s給陣列元素賦初值,這時是與選項A相同的錯誤。

(40)設有如下說明

typedef struct ST

{long a; int b; char c[2];}NEW;

則下面敘述中正確的是________。

A)以上的說明形式非法 B)ST是一個結構體型別

C)NEW是一個結構體型別 D)NEW是一個結構體變數

答案:C

評析:typedef關鍵字用於宣告一個新的型別名代替已有的型別名。

本題中如果沒有用typedef進行定義的話,則struct ST為結構體型別,現在用typedef定義後,相當於用NEW代表了struct ST這一結構體型別,故NEW為結構體型別。

(41)有以下程式

main()

{ int a=1,b;

for(b=l;b<10;b++)

{ if(a>=8)break;

if(a%2==1){a+=5;continue;}

a-=3;

)

printf(“%d\n”,b);

}

程式執行後的輸出結果是________。

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

答案:B

評析:break和continue的區別是:continue語句只結束本次迴圈,而不是終止整個迴圈的執行;而break語句則是結束整個迴圈過程,.不再判斷執行的條件是否成立。

(42)有以下程式

main()

{ char s[]=”l 59″,*p;

p=s;

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

}

程式執行後的輸出結果是________。

A)15 B)16 C)12 D)59

答案:A

評析:本題透過“p=s”將指標變數p指向字元陣列s,在第一次輸出時,由於++和*為同一優先順序,“*p++”相於“+(p++)”。p指向s[1],輸出為s[1]的值。