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

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

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

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

基本操作题

1.请使用VC6或使用【答题】菜单打开考生文件夹projl下的工程proj1。该工程中包含程序文件main.cpp,其中有类CDate(“日期”)和主函数main的定义。程序中位于每个“//ERROR****found****”之后的一行语句有错误,请加以改正。改正后程序的输出结果应为:

原日期:2005—9—25

更新后的日期:2006—4—1

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

#include

#include

using namespace std;

class CDate//日期类

{

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

protected:

CDate(){};

CDate(int d,int m,int y)

{

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

SetDate(int day=d,int month=m,int year=y);

};

void Display();//显示日期

void SetDate(int day,int month,int year)

//设置日期

{m_nDay=day;m_nMonth=month;m_nYear=year;}

private:

int m_nDay;//日

int m_nNonth;//月

int m_nYear;//年

};

void CDate::Display()//显示日期

{

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

cout<<m_nDay<<\\

(1)public:

(2)SetDate(d,m,y);

(3)cout<<m_nYear<<\\

解析:(1)通过主函数中成员函数的调用可知这里应该为公有成员,而且构造函数必须为公有继承。

(2)主要考查考生对成员函数的掌握,程序在这里调用成员函数SetDate,直接把形参代人即可。

(3)题目要求输出原日期:2005—9—25。可以知道输出顺序为:先输出年,其次月,最后是日。

简单应用题

2.请使用VC6或使用【答题】菜单打开考生文件夹proj2下的工程proj2,此工程中声明的Array是一个表示数组的类。一个Array对象可以包含多个整型元素。A唧的成员说明如下:

成员函数add用于向数组的末尾添加一个元素;

成员函数get用于获取数组中指定位置的元素;

数据成员a表示实际用于存储数据的整型数组;

数据成员size表示数组的容量,数组中的元素个数最多不能超过size;

数据成员num表示当前数组中的元素个数。

SonedA=ay是Array的派生类,表示有序数组。SonedArray重新定义了Array中的add函数,以确保有序数组中的元素始终按照升序排列。请在程序中的横线处填写适当的代码,然后删除横线,以实现上述类定义。此程序的正确输出结果应为:

10,9,8,7,6,5,4,3,2,1,

1,2,3,4,5,6,7,8,9,10,

注意:只在横线处填写适当的代码,不要改动程序中的其他内容,也不要删除或移动“//****found****”。

#include

using namespace std;

class Array{

public:

Array(unsigned int s)

{

Size=s;

num=0;

a=new int[s];

}

virtual ~Array() {delete[]a;}

virtual void add(int e)

{

if(num<size){

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

num++;

}

}

int get(unsigned int i)const

{

if(i<size)

return a[i];

return 0;

}

protected:

int*a;

unsigned int Size,num;

};

class SortedArray:public Array{

public:

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

SortedArray(uns igned int s)

:__________{}

virtual void add(int e)

{

if(num>=size)

return;

int i=0,j;

while(i<num){

if(e<a[i])(

for(j=num;j>i;j–)

{

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

_________;

}

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

_________;

break;

}

i++;

}

if(i==num)

a[i]=e;

num++;

}

};

void fun(Array&a)

{

int i;

for(i=10;i>=1;i–){

a.add(i);

}

for(i=0;i<10;i++){

cout<<a.get(i)<<\\

(1)a[num]=e;

(2)Array(s)

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

(4)a[i]=e

解析:(1)考查的是虚函数virtual void add(int e)的定义,即添加一个整型数e到a[num]中。

(2)主要考查的是Array类的派生类sortedArray类的构造函数的定义,定义之前要对基础类初始化。

(3)因为SonedArray类是排序类,所以数组a中的元素要从小到大排序。在if(e<a[i])条件下,要把i后的元素逐个往后移一位,因此此处为a[j]=a[j-1]。<

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

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

推荐资源

客服

扫码添加客服微信

热线

官方客服

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

电话客服:

客服微信:pujinet

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

公众号

扫码关注微信公众号