計算機二級考試C++上機考試試題
試題的練習能夠幫助考生們加深對知識點的理解和鞏固,接下來應屆畢業生小編為大家精心準備了計算機二級考試C++上機考試試題,希望能夠給大家帶來幫助!
一、程序改錯題
使用VC++6.0打開考生文件夾下的源程序文件,使其輸出結果為:
n=0
注意:不要改動main函數,不能增加或刪除行,也不能更改程序的結構,錯誤的語句在//******error******的下面。
試題程序:
#include
//********error*******。
classTC()
{
public:
//********error********
void~TC(){}
TC(intn)
{
cout<<’n’<<’=’< };
//********error********
}
voidmain()
{
TCtest(0);
return;
}
二、簡單應用題
使用VC++6.0打開考生文件夾下的源程序文件。請完成函數fun(char*str,charch)的定義,本函數採用二分法,在已按字母次序從小到大排序的字符數組str中,查找字符ch,若ch在數組中,函數返回字符ch在數組中的下標,否則返回1。
二分法查找的思想是初始查找區間的下界為0,上界為len-1,查找區間的中部後,k=(下界+上界)/2;若list[k]等於ch,查找成功;若list[k]>ch,則新的查找區間的下界不變,上界改為k-1;否則新的查找區間的下界改為k+1,上界不變。在新區間內繼續用二分法查找。
注意:請勿改動主函數main與其他函數中的任何內容,僅在函數fun的花括號中填入所編寫的若干語句。
試題程序:
#include(iostream.h>
intfun(char*str,charch)
{
}
voidmain()
{
charstr[]={’a’,’b’,’C’,’d’,’e’,’f’,’9’,’h’,’i,’
j’,’k’);
charch;
cout<<"請輸入一個字符:"< cin>>ch;
cout<<"輸入字符的位置是:"< return;
}
三、綜合應用題
使用VC++6.0打開考生文件夾下的源程序文件3.cpp,閲讀下列程序説明和代碼,功能如下:
從屏幕輸入數字,然後由大到小插入到指定的鏈中。當輸入0時,表示輸出的數據已經輸入完成,把數據打印到屏幕,並釋放內存。
其中定義的類不完整,按要求完成下列操作,將類的定義補充完整。
(1)在父結點的Next中保存新插入的結點的指針,請在註釋1後添加適當的語句。
(2)把pNext的子結點賦給pNext本身,請在註釋2後添加適當的語句。
(3)判定P的子結點不為空,如果不為空,則打印P中的數據到屏幕,請在註釋3後添加適當的語句。
(4)用t1保存動態申請內存結點的鏈表頭,請在註釋4
後添加適當的語句。
注意:僅在函數指定位置添加語句,請勿改動主函數
main與其他函數中的任何內容。
試題程序:
#include
classTC
{
public:
TC(intdata=O)
{
this->data=data;
this->next=NULL;
}
intdata;
TC*next;
};
voidInsert(TC*P,intdata)
{
TC*temp=newTC(data);
TC*pParent=P:
TC*pNext=p-)next:
while(pNext)
{
if(data>pNext->data)
{
//********1********
temp->next=pNexti
return;
}
else
{
pParent=pNext;
//********2********
}
}
if(pNext==NULL)
{
pParent->next=temp;
return;
}
}
voidprintf(TC*p)
{
//********3********
while()
{
coutdata<<"";
P=P->next;
}
cout< }
voidDelete(TC*p)
{
//********4********
TC*t1=;
TC*t2;
while(t1!=NULL)
{
t2=t1->next:
tl;
t1=t2:
}
}
voidmain()
{
inti=0;
TChead:
do
{
intdata;
cout<<"請輸入一個數字:"< cin>>data;
if(data==O)break;
Insert(&head,data);
}while(1);
printf(&head);
Delete(&head):
return;
}
}
上機考試試題答案與解析
一、程序改錯題
(1)應改為“classTC”。
(2)應改為“~TC(){}”。
(3)應改為“};”。
【解析】本題第1處的“classTC()”為類的定義,根據C++中類的定義格式,類名後面是沒有括號的.,所以第1處應為“classTC”。第2處的“void~TC(){}”是析構函數,C++中析構函數的格式中是沒有函數類型説明的,所以修改為“~TC(){}”。根據C++中類的定義,第3個標識下類結束的“}”缺少分號,即修改為“};”。
二、簡單應用題
intlow=0;//初始查找區間的下界
inthigh;
intk;
for(high=0;str[high]!=0;high++)//求字符串長度
while(10w {
k=(low+high)/2;
if(str[k]==ch)
returnk;
elseif(str[k]>ch)
high=k-l:
elselow=k+1:
}
if(str[low]==ch)
returnlow;
return-1:
【解析】本題首先初始查找區間的下界為0,然後求得字符串長度len,上界為len-1,查找區間的中部後,k=(下界+上界)/2;若list[k]等於ch,查找成功。若list[k]>ch,則新的查找區間的下界不變,上界改為k-1;否則新的查找區間的下界改為k+1,上界不變。
三、綜合應用題
(1)應添加“pParenl->next=telnp;”。
(2)應添加“pNext=pNext->next;”。
(3)將“while()”補充完整為“while(P->next!=NULL)”。
(4)將“TC*t1=;”補充完整為“TC*t1=P->next;”。
【解析】本題第1處要求“在父結點的Next中保存新插入的結點的指針”。對於指針的操作,pParent->next為pParent的子結點,在父結點的Next中保存新插入的結點的指針,即“pParent->next=temp;”。第2處要求“把pNext的子結點賦給pNext本身”。pNext->next為pNext的子結點,把pNext的子結點賦給pNext本身,即“pNext=pNext->next;”。註釋3下是判定P的子結點不為空。P的子結點是p->next。程序中的“while()”缺乏P的子結點不為空的判斷條件,所以修改為“while(P->next!=NULL)”。第4處要求“用t1保存動態申請內存結點的鏈表頭”。P為鏈表,P->next為鏈表頭。程序中的語句“TC*t1=;”中t1沒有被賦值,所以修改為“TC*t1=P->next;”。
-
2016計算機二級《Access》選擇題題庫及答案
(1)在代碼中引用一個窗體控件時,應使用的控件屬性是()。ionx(2)確定一個窗體大小的屬性是()。h和Heighth和Top和Left和Height(3)對話框在關閉前,不能繼續執行應用程序的其他部分,這種對話框稱為()。A.輸入對話框B.輸出對話框C.模態對話框D.非模態對話框(4)Access...
-
2016年計算機二級考試選擇題題庫帶答案
第1題:下列敍述中正確的是(d)。A)棧是"先進先出"的線性表B)隊列是"先進後出"的線性表C)循環隊列是非線性結構D)有序線性表既可以採用順序存儲結構,也可以採用鏈式存儲結構解析:棧是先進後出的線性表,所以A錯誤;隊列是先進先出的線性表,所以B錯誤;循環隊列是線性結構...
-
2016計算機二級考試Java練習題(含答案)
2016年上半年計算機等級考試即將開始,同學們都複習得怎麼樣了呢?下面是本站小編為大家搜索整理的計算機二級考試Java練習題(含答案),供大家參考學習,預祝考生考試順利。練習題一填空題(每空2分,共20分)將每一個空的正確答案寫在答題卡上【6】~【15】序號的橫線上,打...
-
2015年9月全國計算機二級C語言預測題答案
一、選擇題1A2D3B4C5B6C7A8A9B10C11C12A13B14D15B16C17B18A19B20B21B22D23D24D25B26D27B28D29C30A31B32A33B34C35D二、填空題36n/237層次模型38實例39變換型40物理獨立性41k=5423行43max=(a>b)?a:b;441.00000045k=p466047100010481249!=returnj...