計算機二級C++模擬題及答案2017
計算機等級證書是我們找工作的敲門磚,現在越來越多人重視計算機等級考試。下面是小編為大家整理的計算機二級C++模擬題及答案2017,歡迎參考~
計算機二級C++模擬題及答案2017一、綜合應用題
使用VC6打開考生文件夾下的工程kt7_3,此工程包含一個源程序文件kt7_,其中含有一個類Circle的定義,但該類的定義並不完整。請按要求完成下列操作,將類Circle的定義補充完整。
(1)為類Circle增加一個構造函數,該函數有一個參數,並在構造時將該參數值賦給成員radius。將該函數實現為一個非內聯函數,並且使用參數列表的方式將類成員賦值。請在註釋“//**1**”之後添加適當的`語句。
(2)為類Circle增加一個成員函數print( ),使得可以輸出有關圓的信息,比如下列程序
Circlec;
adius(5);
t( );
將輸出:Thecirclehasradiusof5!
請在註釋“//**2**”之後添加適當的語句。
(3)完成友元函數voidCompareR(Circle*c1,Circle*c2)的定義,在屏幕中輸出c1與c2比較radius大小結果,要求使用if-else結構完成。請在註釋“//**3**”之後添加適當的語句。
輸出結果如下:
Thecirclehasradusof5!
Thecirclehasradiusof10!
c1
注意:除在指定位置添加語句之外,請不要改動程序中的其他內容。
源程序文件kt7_清單如下:
#include
classCircle{
public:
Circle( ):radius(5){}
//**1**
voidSetRadius(intr){radius=r;}
intGetRadius( ){returnradius;}
//**2**
friendvoidCompareR(Circle*c1,Circle*c2);
private:
intradius;};
voidCompareR(Circle*c1,Circle*c2)
{//**3**
cout<<"c1>c2"<
else
if((c1->GetRadius( ))==(c2->GetRadius( )))
cout<<"c1=c2"<
else
if((c1->GetRadius( ))<(c2->GetRadius( )))
cout<<"c1
voidmain( )
{Circlec1; 來源:考試大
adius(5);
t( );
Circlec2(10);
t( );
CompareR(&c1,&c2);}
【參考答案】
(1)Circle(intrad):radius(rad){}
(2)voidPrint( ){cout<<"Thecirclehasradiusof"<
(3)if((c1->GetRadius( ))>(c2->GetRadius( )))
【試題解析】
本題考查成員函數的定義與實現,友元函數,if分支語句等知識點。友元函數的類體外的定義與一般函數一樣,其中if-else的使用,else總是與其最近的那個if配對使用的,書寫時最好使用縮進格式,將配對的if-else對齊,以免出錯。
二、改錯題
使用VC6打開考生文件夾下的工程kt8_1,此工程包含一個源程序文件kt8_,但該程序運行有問題,請改正程序中的錯誤,使程序的輸出結果如下:
f1functionofderive
f2functionofbase
f4functionofbase
源程序文件kt8_清單如下:
#include
classbase
{ public:
/**********found**********/
voidf1(){cout<<"f1functionofbase"<
virtualvoidf2(){cout<<"f2functionofbase"<
virtualvoidf3(){cout<<"f3functionofbase"<
voidf4(){cout<<"f4functionofbase"<
/**********found**********/
classderive::publicbase
{ voidf1(){cout<<"f1functionofderive"<
voidf2(intx){cout<<"f2functionofderive"<
voidf4(){cout<<"f4functionofderive"<
voidmain()
{ base*p;
deriveobj2;
/**********found**********/
p=obj2;
p->f1();
p->f2();
p->f4(); }
【參考答案】
(1)將void f1(){ cout<<"f1 function of base"<
改為:virtual void f1(){ cout<<"f1 function of base"<
(2)將class derive::public base
改為:class derive:public base
(3)將p=obj2;
改為:p=&obj2;
【試題解析】
(1)主要考查對虛函數的深刻理解,虛函數是動態聯編的基礎,也是實現多態性的重要方法,它可以根據不同的情況動態的選擇執行哪一個函數。在派生類中實現虛函數應該滿足與基類的同名函數完全相同,並且使用關鍵字virtual修飾,本題中由輸出結果中的f1 function of derive可知,必須將基類base的成員函數f1()定義為虛函數;
(2)主要考查對派生類定義格式的掌握,應該使用“:”後面是繼承列表,而“::”是作用域符;
(3)主要考查類對象的定義與使用,p是一個指針類型的變量,給它的賦值應該是一個地址,即使用取地址操作符&。
-
2015下半年全國計算機二級Java考試仿真題(附答案)
一、選擇題(1)已知一棵二叉樹前序遍歷和中序遍歷分別為ABDEGCFH和DBGEACHF,則該二叉樹的後序遍歷為A)GEDHFBCAB)DGEBHFCAC)ABCDEFGHD)ACBFEDHG(2)樹是結點的集合,它的根結點數目是A)有且只有1B)1或多於1C)0或1D)至少2(3)如果進棧序列為e1,e2,e3,e4,則可能的出棧序...
-
二級計算機選擇題試題答案
一、選擇題1、任何控件都有的屬性是()。ColorionerStyle2、設計數據庫的存儲結構屬於()A.需求分析B.概念設計C.邏輯設計D.物理設計3、某人創建了1個工程,其中的窗體名稱為Form1;之後又添加了1個名為Form2的窗體,並希望程序執行時先顯示Form2窗體,那麼,他需要做的工...
-
計算機等級考試二級VB試題及答案
一、選擇題(1)假設線性表的長度為n,則在最壞情況下,冒泡排序需要的比較次數為A)log2nB)n2C)O(n1..5)D)n(n-1)/2正確答案:D(2)算法分析的目的是A)找出數據結構的合理性B)找出算法中輸入和輸出之間的關係C)分析算法的易懂性和可靠性D)分析算法的效率以求改進正確答...
-
2016年9月計算機二級Access預測試題及答案
(1)程序流程圖中帶有箭頭的線段表示的是()。A.圖元關係B.數據流C.控制流D.調用關係(2)結構化程序設計的基本原則不包括()。A.多態性B.自頂向下C.模塊化D.逐步求精(3)軟件設計中模塊劃分應遵循的準則是()。A.低內聚低耦合B.高內聚低耦合C.低內聚高耦合D.高內聚...