計算機二級C++模擬試題及答案
在日常學習和工作生活中,我們最離不開的就是試題了,試題可以幫助學校或各主辦方考察參試者某一方面的知識才能。那麼你知道什麼樣的試題才能有效幫助到我們嗎?下面是小編收集整理的計算機二級C++模擬試題及答案,僅供參考,希望能夠幫助到大家。
計算機二級C++模擬試題及答案1
一、選擇題
1.樹是結點的集合,它的根結點數目是( )
A.有且只有1
B.1或多於1
C.0或1
D.至少2
【參考答案】A
2.在設計程序時,應採納的原則之一( )
A.不限制goto語句的使用
B.減少或取消註解行
C.程序越短越好
D.程序結構應有助於讀者理
【參考答案】D
3.下列敍述中,不屬於軟件需求規格説明書的作用的是( )
A.便於用户、開發人員進行理解和交流
B.反映出用户問題的結構,可以作為軟件開發工作的基礎和依據
C.作為確認測試和驗收的依據
D.便於開發人員進行需求分析
【參考答案】D
4.單個用户使用的數據視圖的描述稱為( )
A.外模式
B.概念模式
C.內模式
D.存儲模式
【參考答案】A
語言又稱為( )
A.結構化定義語言
B.結構化控制語言
C.結構化查詢語言
D.結構化操縱語言
【參考答案】C
6.若某二叉樹的前序遍歷訪問順序是abdgcefh,中序遍歷訪問順序是dgbaechf,則其後序遍歷的結點訪問順序是( )
efha
cfha
echf
hfca
【參考答案】D
7.軟件工程的理論和技術性研究的內容主要包括軟件開發技術和( )
A.消除軟件危機
B.軟件工程管理
C.程序設計自動化
D.實現軟件可重用
【參考答案】B
8.在軟件測試設計中,軟件測試的主要目的是( )
A.實驗性運行軟件
B.證明軟件正確
C.找出軟件中全部錯誤
D.發現軟件錯誤而執行程序
【參考答案】D
9.索引屬於( )
A.模式
B.內模式
C.外模式
D.概念模式
【參考答案】B
10.數據庫系統的核心是( )
A.數據庫
B.數據庫管理系統
C.模擬模型
D.軟件工程
【參考答案】B
11.下面關於類和對象的描述中,錯誤的是( )
A.類就是C語言中的結構體類型,對象就是C語言中的結構體變量
B.類和對象之間的關係是抽象和具體的關係
C.對象是類的實例,一個對象必須屬於一個已知的類
D.類是具有共同行為工的若干對象的`統一描述體
【參考答案】A
12.設inta=10,b=11,c=12;,表達式(a+b)
A.2
B.0
C.-2
D.1
【參考答案】B
13.下列語句中不是死循環的是( )
=10;
(inti=1;i<10;i++)
=0;
=1;
while(1){do{for(;;)
{i--;i++;i=i+1;
i--;}}while(i>=0);
if(i==1)break;
}
【參考答案】A
14.下面關於數組的描述錯誤的是( )
A.在C++語言中數組的名字就是指向該數組第一個元素的指針
B.長度為n的數組,下標的範圍是0~n-1
C.數組的大小必須在編譯時確定
D.數組只能通過值參數和引用參數兩種方式傳遞給函數
【參考答案】D
15.下面的哪個選項不能作為函數的返回類型?( )
【參考答案】C
16.下列程序的輸出結果為( )
include
intfunc(intn)
{if(n<1)return1;
elsereturnn+func(n-1);
return0;}
voidmain( )
{cout<
A.0
B.10
C.15
D.16
【參考答案】D
17.以下程序中,錯誤的行為( )
ude
sA
3.{
ic:
=2;
6.A(intval){cout<
7.~A( ){}
8.{;
main( )
10{
(0);
12.}
A.5
B.6
C.7
D.11?
【參考答案】A
18.下面程序的運行結果為( )
includeclassA{intnum;public:A(inti){num=i;}A(A&a){num=++;}voidprint( ){cout<};voidmain( {Aa(1),b(a);t( );
t( );
A.11
B.12
C.21
D.22
【參考答案】C
19.如果類A被説明成類B的友元,則( )
A.類A的成員即類B的成員
B.類B的成員即類A的成員
C.類A的成員函數不得訪問類B的成員
D.類B不一定是類A的友元
【參考答案】D
20.建立派生類對象時,3種構造函數分別是a(基類的構造函數)、b(成員對象的構造函數)、c(派生類的構造函數)這3種構造函數的調用順序為( )
【參考答案】A
21.下面關於模板的描述,錯誤的是( )
A.函數模板和類模板的參數可以是任意的數據類型
B.類模板不能直接使用,必須先實例化為相應的模板類,然後定義了模板類的對象後才能使用
C.函數模板不能直接使用,需要實例化為模板函數後才使用
D.類模板的成員函數都是模板函數
【參考答案】A
22.下面程序的運行結果是( )
include
voidmain( )
{
intnum=1;
int&ref=num;
ref=ref+2;
cout<
num=num+3;
cout<
}
A.13
B.16
C.36
D.33
【參考答案】C
23.下列程序的運行結果為( )
include
inti=0;
classA{
public:
A( ){i++;}
};
voidmain( )
{Aa,b[3],xc;
c=b;
cout<
A.2
B.3
C.4
D.5
【參考答案】C
24.下列字符串中可以用C++語言標識符的是( )
A._1234
~~bar
ua
D.34var
【參考答案】A
25.下列語句的輸出結果( )
cout<
A.5
B.14
C.8
D.輸出項不合法,無正常輸出
【參考答案】A
26.若有如下語句( )
include
voidmain( )
{intx=3;
do{
x=x-2;
cout<
}while(!(--x));
}
則上面程序段
A.輸出的是1
B.輸出的是1和-2
C.輸出的是3和0
D.是死循環
【參考答案】B
27.以下程序中調用cin函數給變量a輸入數值的方法是錯誤的,其錯誤原因是( )
include
voidmain( )
{intxp,xq,a,b;
p=&a;
cout<<″inputa:″;
cin>>p;}
表示的是指針變量P的地址
B.p表示的是變量a的地址,而不是變量a的值
表示的是指針變量p的值
只能用來説明p是一個指針變量
【參考答案】B
28.有以下程序
include
voidfun(inta,intb,intc)
{a=456,b=567,c=678;}
voidmain( )
{intx=10,y=20,z=30;
fun(x,y,z);
輸出結果是( )
A.30,20,10
B.10,20,30
C.456,567,678
D.678,567,456
【參考答案】B
29.下列定義中p指向的地址可更改,但xp不能夠更改的是( )
tintxP
constp;
tintxconstp;
p;
計算機二級C++模擬試題及答案2
1.若有以下數組説明,則i=10;a[a[i]]元素數值是(C )。
int a[12]={1,4,7,10,2,5,8,11,3,6,9,12};
A、10
B、9
C、6
D、5
先算a[a[i]]內層的a[i],由於i=10,因此a[i]即a[10].
a[10]對應下面數組中的元素為9. 因此a[a[i]]即為a[9]
a[9]對應下面數組中的元素為6. 因此a[9]即為6
2.若有説明:int a[][3]={{1,2,3},{4,5},{6,7}}; 則數組a的第一維的大小為: ( B )
A、2
B、3
C、4
D、3 6 9
二維數組的一維大小,即指二維數組的行數,在本題中,按行對二維數組賦值,因此內層有幾個大括號,數組就有幾行
3.對二維數組的正確定義是(C )
詳見教材P149~152,二維數組的定義、初始化
類型符 數組名 [常量表達式][常量表達式]
二維數組可以看做是矩陣
類型符是指數組中數組元素的類型;數組名要符合標識符命名規則;第一個常量表達式是指數組的行數;第二個常量表達式是指數組的列數;常量表達式的值只能是整數,不可以是變量,而且從1開始計數。
一維數組初始化時可以省略數組長度
二維數組初始化時可以省略行數,但不能省略列數
選項A,B,都省略了列數
選項D,不符合二維數組定義的一般形式,行、列常量表達式應該放在不同的[]中
A、int a[ ][ ]={1,2,3,4,5,6};
B、int a[2] []={1,2,3,4,5,6};
C、int a[ ] [3]={1,2,3,4,5,6};
D、int a[2,3]={1,2,3,4,5,6};
4.已知int a[3][4];則對數組元素引用正確的是__C___
A、a[2][4]
B、a[1,3]
C、a[2][0]
D、a(2)(1)
5.C語言中函數返回值的類型是由 A 決定的.
A、函數定義時指定的類型
B、 return語句中的表達式類型
C、 調用該函數時的實參的數據類型
D、形參的數據類型
6. 在C語言中,函數的數據類型是指(A )
A、 函數返回值的數據類型
B、 函數形參的數據類型
C、 調用該函數時的實參的數據類型
D、任意指定的數據類型
7.在函數調用時,以下説法正確的是( B )
A、函數調用後必須帶回返回值
B、實際參數和形式參數可以同名
C、函數間的數據傳遞不可以使用全局變量
D、主調函數和被調函數總是在同一個文件裏
8. 在C語言中,表示靜態存儲類別的關鍵字是: ( C )
A、 auto
B、 register
C、static
D、extern
9.未指定存儲類別的變量,其隱含的存儲類別為(A )。
A、auto
B、static
C、extern
D、register
10. 若有以下説明語句:
struct student
{ int num;
char name[ ];
float score;
}stu;
則下面的敍述不正確的是: (D )
A、 struct是結構體類型的關鍵字
B、 struct student 是用户定義的結構體類型
C、 num, score都是結構體成員名
D、 stu是用户定義的結構體類型名
11.若有以下説明語句:
struct date
{ int year;
int month;
int day;
}brithday;
則下面的敍述不正確的是__C___.
A、 struct是聲明結構體類型時用的關鍵字
B、 struct date 是用户定義的結構體類型名
C、 brithday是用户定義的結構體類型名
D、year,day 都是結構體成員名
12. 以下對結構變量stul中成員age的非法引用是 B
struct student
{ int age;
int num;
}stu1,xp;
p=&stu1;
A、
B、
C、 p->age
D、(xp)
13.設有如下定義:
struck sk
{ int a;
float b;
}data;
int xp;
若要使P指向data中的a域,正確的賦值語句是 C
A、 p=&a;
B、 p=datA、a;
C、p=&datA、a;
D、xp=datA、a;
14.設有以下説明語句:
typedef struct stu
{ int a;float b;} stutype;
則下面敍述中錯誤的是( D )。
A、struct是結構類型的關鍵字
B、struct stu是用户定義的結構類型
C、a和b都是結構成員名
D、stutype是用户定義的結構體變量名
15.語句int xp;説明了 C 。
A、p是指向一維數組的指針
B、p是指向函數的指針,該函數返回一int型數據
C、p是指向int型數據的指針
D、p是函數名,該函數返回一指向int型數據的指針
16、以下語句的輸出結果是( D)。
int a=-1,b=4,k;
k=(+ +a<0)&&!(b - -<=0);
printf("%d,%d,%d ",k,a,b);
A. 1,0,4
B. 1,0,3
C. 0,0,3
D. 0,0,4
17、下列程序的輸出結果是(D )。
char xp1="abcd", xp2="ABCD", str[50]="xyz";
strcpy(str+2,strcat(p1+2,p2+1));
printf("%s",str);
A. xyabcAB
B. abcABz
C. ABabcz
D. xycdBCD
18、執行下面的程序後,a的值是(B )。
define SQR(X) XxX
main( )
{ int a=10,k=2,m=1;
a/=SQR(k+m)/SQR(k+m);
printf("%d ",a); }
A. 10
B. 1
C. 9
D. 0
19、設A為存放(短)整型的一維數組,如果A的首地址為P,那麼A中第i 個元素的地址為( B)。
A.P+ix2
B. P+(i-1)x2
C. P+(i-1)
D. P+i
20、下列程序執行後輸出的結果是( A)。
int d=1;
fun (int p)
{ int d=5;
d + =p + +;
printf("%d,",d); }
main( )
{ int a=3;
fun(a);
d + = a + +;
printf("%d ",d); }
A. 8, 4
B. 9, 6
C. 9, 4
D. 8, 5
21、表達式:10!=9的值是(D )。
A. true
B. 非零值
C. 0
D. 1
22、若有説明: int i,j=7, xp=&i;, 則與i=j; 等價的語句是( B)。
A. i= xp;
B. xp=x&j;
C. i=&j;
D. i=x xp;
23、不能把字符串:Hello!賦給數組b的語句是( B)。
A. char b[10]={’H’,’e’,’l’,’l’,’o’,’!’};
B. char b[10]; b="Hello!";
C. char b[10]; strcpy(b,"Hello!");
b[10]="Hello!";
24、在C程序中有如下語句:char xfunc(int x,int y); 它是(C )。
A. 對函數func的定義。
B. 對函數func的調用。
C.對函數func的原型説明。
D. 不合法的。
25、以下程序的輸出結果是( D)。
char str[15]=”hello!”;
printf(“%d ”,strlen(str));
A. 15
B. 14
C. 7
D. 6
26[單選題] 以下敍述中正確的是( )
A.用户自己定義的函數只能調用庫函數
B.實用的C語言源程序總是由一個或多個函數組成
C.不同函數的形式參數不能使用相同名稱的'標識符
D.在C語言的函數內部,可以定義局部嵌套函數
參考答案:B
參考解析:A選項中,”用户自己定義的函數只能調用庫函數”描述是不正確的,也可以調用自定義函數;C選項中,對於不同函數的形式參數可以使用相同名稱的標識符;D選項中,關於函數的定義不可以嵌套,但函數的調用可以嵌套。因此B選項正確。
27[單選題] 以下關於C語言數據類型使用的敍述中錯誤的是( )。
A.若要處理如“人員信息”等含有不同類型的相關數據,應自定義結構體類型
B.若要保存帶有多位小數的數據,可使用雙精度類型
C.若只處理“真”和“假”兩種邏輯值,應使用邏輯類型
D.整數類型表示的自然數是準確無誤差的
參考答案:C
參考解析:C語言中沒有邏輯類型,所以c錯誤。若要保存帶有多位小數的數據,可以用單精度類型也可以用雙精度類型。處理包含不同類型的相關數據可以定義為結構體類型。整數類型可以無誤差的表示自然數。
28[單選題] 下面選項中關於編譯預處理的敍述正確的是
A.預處理命令行必須使用分號結尾
B.凡是以號開頭的行,都被稱為編譯預處理命令行
C.預處理命令行不能出現在程序的最後一行
D.預處理命令行的作用域是到最近的函數結束處
參考答案:B
參考解析:本題考查預編譯的預編譯處理命令行,預處理命令行不能以分號結尾,所以A選項錯誤,預處理命令行可以出現在程序的最後一行,預處理命令行作用域是整個文件。
29[單選題] 有以下程序
程序的輸出結果是
A.0B.1C.9D.10
參考答案:B
參考解析:本題考查宏定義,宏定義只是做個簡單的替換。執行SQR(k+m)/SQR(k+m)=k+mxk+m/k+m}k+m=15/2,a/=SQR(k+m)/SQR(k+1TI)的結果為1,選項B正確。
30[單選題] 設--X樹共有150個結點,其中度為l的結點有l0個,則該---X樹中的葉子結點數為( )。
A.71B.70C.69D.不可能有這樣的二叉樹
參考答案:D
參考解析:在樹結構中,一個結點所擁有的後件個數稱為該結點的度,所有結點中最大的度稱為樹的度。對任何一棵二叉樹,度為0的結點總是比度為2的結點多一個。如果有一棵二叉樹,結點總數為l50,假設度為0的結點個數為n,則有n+10+n一1=150,n=70.5,由於結點個數必須是整數,所以不可能有題目中這樣的二叉樹。故選擇D選項。
31[單選題] 有以下程序:
程序運行後的輸出結果是( )。
A.2.3B.1,3C.1,4D.1,2
參考答案:B
參考解析:在f(int+P,int 4 q)函數中,執行P=P+1是將P所對應的地址加1,而0 q=+q+1是將q所指向的n的地址所對應的值加1,所以m的得知所對應的值沒有變,而n的值則為3了。因此B選項正確。
32[單選題] 以下選項中,能用作用户標識符的是( )。
A.-0-B.8-;gned
參考答案:A
參考解析:C語言中標識符由字母、下劃線、數字組成,且開頭必須是字母或下劃線。另外,關鍵字不能作為標識符。8中以數字8開頭,所以錯誤。c與D中用的是關鍵字void與unsigned,所以錯誤。
33[單選題] 以下敍述正確的是( )。
A.表達式sizeof(FILEx)==sizeof(intx)的值為真
B.文件指針的值是一個整數,它的值一定小於文件字節數
C.文件指針的值是所指文件的當前讀取位置
D.使用fscanf函數可以向任意類型的文件中寫入任意數量的字符
參考答案:A
參考解析:
slzeof(FILE})=4,因為file·為指針,指針的大小4,sizeof(int·)=4,理由同前面。文件指針的值是地址,是一個16進制的數,它的值不一定小於文件字節數,因此選項8錯誤。文件指針是所指文件的當前讀取位置,而不是文件指針的值因此選項C錯誤。mgscanf(FILE-stream,constchar}format,[argument…]fmanf函數可以向任意類型的文件,寫入任意數量不能超過系統的緩衝區,寫文件先寫入緩衝區,最後一起寫入文件,因此選項D錯誤。答案為A選項。