首页 > 全部 > 二级C++ > 国家二级C++机试(操作题)模拟试卷281

国家二级C++机试(操作题)模拟试卷281

本单篇文档共4673字,内容预览3600字,预览为有答案版,源文件无水印,下载后包含无答案空白卷版和有答案版,同时也有计算机类NCRE全国计算机二级整科真题模拟题,讲义课件,思维导图,易错高频题等下载。
二级C++ 章节练习 6847人下载
价格: 1.20 原价:¥7.00
收藏

国家二级C++机试(操作题)模拟试卷281

基本操作题

1.请使用VC6或使用【答题】菜单打开考生文件夹proj1下的工程proj1,此工程中含有一个源程序文件proj1.cpp。其中位于每个注释“//ERROR*********found*********”之后的一行语句存在错误。请改正这些错误,使程序的输出结果为:

NUM=0

Value=1

注意:只修改注释“//ERROR ****found****”的下一行语句,不要改动程序中的其他内容。

//proj1.cpp

#include<iostream>

using namespace std;

class MyClasS{

int_i;

friend void Increment

(MyClass&f);

public:

const int NUN;

//ERROR *******found*******

MyClass(int i=0){NUN=0;

_i=i;

}

int GetValue()const { return_i;}

};

//ERROR*******found*******

void Increment(){f._i++;}

int main()

{

NyClass obj;

//ERROR *******found*******

NyClass∷Increment(obj);

cout <<\\

(1)MyClass(int i=0):NUM(0){

(2)void Increment(MyClass& f){f._i++;}

(3)Increment(obj);

解析:(1)主要考查考生对常量数据成员初始化方法的掌握,常量数据成员的初始化只能通过构造函数的成员初始化列表进行,并且要使用关键字const修饰。该题的前一条语句const int NUM;,说明NUM是常量数据成员。

(2)主要考查考生对友元函数的掌握,友元函数的定义与声明要一致,先看该友元函数的声明部分:friend void Increment(MyClass& f);,返回类型为void,函数参数为MyClass& f;再比较出错的语句:void Increment(){f._i++;},错误在于该函数没有参数,应把MyClass& f填在括号内。

(3)主要考查友元函数的调用,友元函数并不属于类,因此调用友元函数时不需要添加类名及作用域,只需要像调用普通函数一样即可。

简单应用题

2.请使用VC6或使用【答题】菜单打开考生文件夹proj2下的工程proj2,此工程包含一个源程序文件proj2.cpp。其中定义了Score类。

Score是一个用于管理考试成绩的类。其中,数据成员_s指向存储成绩的数组,_n表示成绩的个数;成员函数Sort使用冒泡排序法将全部成绩按升序进行排列。

请在程序中的横线处填写适当的代码,然后删除横线,以实现Score类的成员函数sort。

注意:只在指定位置编写适当代码,不要改动程序中的其他内容,也不要删除或移动“//****found****”。

//proj2.cpp

#include<iostream>

#include<cstdlib>

#include<ctime>

using namespace std;

class Score{

public:

Score(double*s,int n):_s(s),_(n){)

double GetScore(int i)const

{return _s[i];}

void Sort();

private:

double *_s;

int n;

};

void Score∷Sort()

{

//********found********

for(int i=0;i<_n-1;_______)

//********found********

for(int j=_______;j>i;j–)

if(_s[j]<_s[j-1])

( //交换_s[j]和_s[j-1]

double t=_s[j];

//********found********

________:

//********found********

________;

}

}

int main()

{

const int NUN =10;

double s[NUM];

stand(time(0));

for(int i=0;i<NUN i++)

s[i]=double(rand())/

RAND_MAX * 100;

Score ss(s,NUM);

ss.Sort();

for(int j=0;J<NUM;j++)

cout << ss.GetScore(J) <<end1;

return 0;

}

(1)i++

(2)_n-1

(3)_s[j]=_s[j-1]

(4)_s[j-1]=t

解析:(1)主要考查for循环语句,从题目要求可知循环变量i要从0到_n-2,因此i要递增操作,即i++。

(2)主要考查考生对冒泡排序的掌握,这里要求从后往前扫描,比较相邻两个元素,若后者小则交换,因此在这里下标j要从最后开始,即int j=_n_1。

(3)考查交换算法,在if语句中_s[j]<_s[j-1]满足条件,则实现交换。因为已经把_s[j]的值赋给了中间变量t,所以这里要把_s[j-1]的值赋给_s[j],即_s[j]=_s[j-1];。

(4)考查交换算法,这里只需把中间变量t中的值赋给_s[j-1]即可。

综合应用题

3.请使用VC6或使用【答题】菜单打开考生文件夹proj3下的工程prog3,其中声明了ValArray类,该类在内部维护一个动态分配的整型数组。ValArray类的复制构造函数应实现对象的深层复制。请编写ValArray类的复制构造函数。在main函数中给出了一组测试数据,此种情况下程序的输出应该是:

ValArray v1={1,2,3,4,5}

ValArray v2={2,2,2,2,2}

要求:

补充编制的内容写在“//*******333*******”与“//********666********”之间。不要修改程序的其他部分。

注意:

相关文件包括:main.cpp、ValArray.h。

程序最后调用writeTo

本文档预览:3600字符,共4673字符,源文件无水印,下载后包含无答案版和有答案版,查看完整word版点下载

剩余未完,查看全文
收藏
国家二级C++机试(操作题)模拟试卷281

推荐资源

客服

扫码添加客服微信

热线

官方客服

如遇问题,请联系客服为您解决

电话客服:

客服微信:pujinet

工作时间:9:00-18:00,节假日休息

公众号

扫码关注微信公众号