首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
请使用VC6或使用【答题】菜单打开考生文件夹proj2下的工程proj2,此工程中声明的Array是一个表示数组的类。一个Array对象可以包含多个整型元素。Array的成员说明如下: 成员函数add用于向数组的末尾添加一个元素; 成员函数
请使用VC6或使用【答题】菜单打开考生文件夹proj2下的工程proj2,此工程中声明的Array是一个表示数组的类。一个Array对象可以包含多个整型元素。Array的成员说明如下: 成员函数add用于向数组的末尾添加一个元素; 成员函数
admin
2017-02-21
39
问题
请使用VC6或使用【答题】菜单打开考生文件夹proj2下的工程proj2,此工程中声明的Array是一个表示数组的类。一个Array对象可以包含多个整型元素。Array的成员说明如下:
成员函数add用于向数组的末尾添加一个元素;
成员函数get用于获取数组中指定位置的元素;
数据成员a表示实际用于存储数据的整型数组;
数据成员size表示数组的容量,数组中的元素个数最多不能超过size;
数据成员hum表示当前数组中的元素个数。
SonedArray是Array的派生类,表示有序数组。SortedArray重新定义了Array中的add函数,以确保有序数组中的元素始终按照升序排列。请在程序中的横线处填写适当的代码,然后删除横线,以实现上述类定义。此程序的正确输出结果应为:
10,9,8,7,6,5,4,3,2,1,
1,2,3,4,5,6,7,8,9,10,
注意:只在横线处填写适当的代码,不要改动程序中的其他内容,也不要删除或移动“//****found****”。
#include<iostream>
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
;
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
){
for(j=num;j>i;j-)
{
//**********found**********
__________;
}
//**********found**********
__________;
break;
}
i++;
}
if(i=num)
a
=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) <<",";
}
cout << end1;
}
int main()
{
Array a(10);
fun(a);
SortedArray sa(10);
fun(sa);
return 0;
}
选项
答案
(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)因为SortedArray类是排序类,所以数组a中的元素要从小到大排序。在if(e<a
)条件下,要把i后的元素逐个往后移一位,因此此处为a[j]=a[j-1]。
(4)主要考查虚函数virtual void add(int e)在派生类SortedArray类中的定义,把插入的数据放在数组a的第i+1个位置,即a
=e;。
转载请注明原文地址:https://kaotiyun.com/show/VBAp777K
本试题收录于:
二级C题库NCRE全国计算机二级分类
0
二级C
NCRE全国计算机二级
相关试题推荐
将x+y*z中的“+”用成员函数重载,“*”用友元函数重载应写为【】。
以下程序的输出结果是【】。#include<iostream.h>unsignedfun(unsignednum){unsignedk=1;do{k*=num%10;n
软件开发的结构化生命周期方法将软件生命周期划分成
假设inta=1,b=2;则表达式a+++--b的值为【】。
开发一个C++语言程序的步骤通常包括编辑、【】、链接、运行和调试。
只能作为成员函数重载的是
如下程序定义了“单词”类word,类中重载了
设数组data[m]作为循环队列SQ的存储空间,front为队头指针,rear为队尾指针,则执行出队操作后其头指针front值为( )。
度为10的线性表进行冒泡排序,在最坏情况下需要比较的次数为______。
栈和队列的共同特点是
随机试题
坚持走中国特色军民融合式发展路子,这里的“军民融合”源于我党的()
行政法规
肾病综合征中常见的病理类型应不包括
小儿汗证的最基本的病机是()
在一起建设单位诉施工单位工程质量纠纷的诉讼中,双方均认可2003年和2005年建设单位两次单独委托鉴定机构对工程质量进行的鉴定。施工单位认为2003年鉴定结论可以证明当时工程施工质量不存在缺陷,但是建设单位拒绝出具该份鉴定结论,则()。
环境影响评价是指对规划和建设项目实施后可能造成的环境影响进行( ),提出预防或者减轻不良环境影响的对策和措施,实行跟踪监测的方法与制度。
幼儿园的教育内容是全面的、启蒙的,各领域的内容相互渗透,从不同角度促进幼儿()等方面的发展。
结合自身经历及报考职位,请谈谈你在以后的工作中如何提高工作效率。
秦朝法律规定,多少人以上的共犯是重大犯罪()
在自治系统内部的各个路由器之间,运行的是内部网关协议IGP。早期的IGP叫做(51),它执行(52)。当网络规模扩大时,该算法使得传送的路由信息太多,增加了网络负载,后来又出现了执行最短路径优先算法的IGP。按照这种协议,每个路由器向网络中的其他路由器发布
最新回复
(
0
)