計算機(jī)等級考試二級C++模擬題及解析10上機(jī)部分
一、改錯題
使用VC6打開考生文件夾下的工程kt15_1,此工程包含一個源程序文件kt15_1.cpp,但該程序運(yùn)行有問題,請改正程序中的錯誤,使該程序的輸出結(jié)果為:
Previous=9,Next=11
源程序文件kt15_1.cpp清單如下:
#include<iostream.h>
/*****************found*****************/
intmain()
{ intx=10,y,z;
prevnext(x,y,z);
cout<<"Previous="<<y<<",Next="<<z<<endl;
return0; }
/*****************found*****************/
voidprevnext(intx,intprev,intnext)
{ /*****************found*****************/
prev=x--;
next=++x; }
【參考答案】(1)在main()函數(shù)前缺少prevnext函數(shù)聲明
應(yīng)添加:void prevnext (int,int &,int &);
。2)將void prevnext (int x, int prev,int next)
改為:void prevnext (int x, int &prev,int &next)
。3)將prev=x--;改為:prev=x-1;
【試題解析】
。1)函數(shù)在使用前必須已經(jīng)被定義,main()中調(diào)用prevnext函數(shù),而該函數(shù)的實現(xiàn)在main()之后,所以在main()之前必須添加該函數(shù)的聲明;
。2)由運(yùn)行結(jié)果可知,通過函數(shù)prevnext調(diào)動要改變main()中的實參值,所以prev和next都應(yīng)為引用型參數(shù);
。3)由運(yùn)行結(jié)果prev=x-1,而源程序的prev=x,x=x-1,這里涉及運(yùn)算符的優(yōu)先級問題。
二、簡單應(yīng)用題
請編寫一個函數(shù)fun(intx,intn),該函數(shù)返回x的n次冪的值,其中x和n都是非負(fù)整數(shù)。x的n次冪的計算方法是1與x相乘n次,如x的20次冪的計算為1與x相乘20次。
注意:部分源程序已存在文件kt15_2.cpp中。
請勿修改主函數(shù)main和其他函數(shù)中的任何內(nèi)容,僅在函數(shù)fun的花括號中填寫若干語句。
如輸入3和4,輸出結(jié)果如下:
34
81
文件kt15_2.cpp清單如下:
#include<iostream.h>
doublefun(intx,intn){
}
voidmain()
{ intx,n;
cin>>x>>n;
cout<<fun(x,n)<<endl; }
【參考答案】
if(x==0) return 0;
if(n==0) return 1;
int y=1;
for(int i=0;i<n;i++) y*=x;
return y;
【試題解析】
本題主要考查用基本控制結(jié)構(gòu)與函數(shù)知識解決實際問題的能力。求x的n次冪是數(shù)學(xué)中常用的運(yùn)算,編程時在x=0與n=0時需特殊處理。
相關(guān)推薦:計算機(jī)等級考試二級C++模擬試題15套(上機(jī))北京 | 天津 | 上海 | 江蘇 | 山東 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
廣東 | 河北 | 湖南 | 廣西 | 河南 |
海南 | 湖北 | 四川 | 重慶 | 云南 |
貴州 | 西藏 | 新疆 | 陜西 | 山西 |
寧夏 | 甘肅 | 青海 | 遼寧 | 吉林 |
黑龍江 | 內(nèi)蒙古 |