首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
请使用VC6或使用【答题】菜单打开考生文件夹proj2下的工程proj2,此工程中声明的Array是一个表示数组的类。一个Array对象可以包含多个整型元素。Array的成员说明如下: 成员函数add用于向数组的末尾添加一个元素; 成员函数get用于获取数
请使用VC6或使用【答题】菜单打开考生文件夹proj2下的工程proj2,此工程中声明的Array是一个表示数组的类。一个Array对象可以包含多个整型元素。Array的成员说明如下: 成员函数add用于向数组的末尾添加一个元素; 成员函数get用于获取数
admin
2019-05-29
108
问题
请使用VC6或使用【答题】菜单打开考生文件夹proj2下的工程proj2,此工程中声明的Array是一个表示数组的类。一个Array对象可以包含多个整型元素。Array的成员说明如下:
成员函数add用于向数组的末尾添加一个元素;
成员函数get用于获取数组中指定位置的元素;
数据成员a表示实际用于存储数据的整型数组;
数据成员size表示数组的容量,数组中的元素个数最多不能超过size;
数据成员num表示当前数组中的元素个数。
$ortedArray是Array的派生类,表示有序数组。SortedArray重新定义了Array中的add函数,以确保有序数组中的元素始终按照升序排列。请在程序中的横线处填写适当的代码,然后删除横线,以实现上述类定义。此程序的正确输出结果应为:
10,9,8,7,6,5,4,3,2,1,
l,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
//**********found**********
num++;
}
)
int get(unsigned int i)const
{
if(i
return a
;
return 0;
}
protected:
int*a;
unsigned int size,num;
};
class SortedArray:public Array{
public:
//********** found**********
SortedArray(unsigned int s) :
___________{}
virtual void add(int e)
{
if(num>=size)
return;
int i=0,j;
while(i
if(e
){
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<1 0;i++){
cout<
}
cout<
}
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
解析
本题考查数组类Array及Array的派生类SortedArray,其知识点涉及构造函数、析构函数、虚函数和动态数组。一般考到函数时,首先要看函数名,通过函数名称能大概知道该函数的功能,比如Array类中的virtual void add(int e)函数,看到这个函数我们能得到如下信息。
(1)有关键字virtual,说明该函数是虚函数,在Array类的派生类里肯定会有对add函数的定义。
(2)有关键字void,说明此函数没有返回值。
(3)add的意思是添加,它的形参是int e,那么我们大概可以猜到该函数的功能是把整型数值e添加到数组a中。
【解题思路】
(1)考查的是虚函数virtual void add(int e)的定义,即添加一个整型数e到a[num]中。
(2)主要考查的是Array类的派生类Sorted.Array类的构造函数的定义,定义之前要对基础类初始化。
(3)因为SortedArray类是排序类,所以数组a中的元素要从小到大排序。在if(e
)条件下,要把i后的元素逐个往后移一位,因此此处为a[j]=a[j一1]。
(4)主要考查虚函数virtual void add(int e)在派生类SortedArray类中的定义,把插入的数据放在数组a的第i+1个位置,即a
=e;。
转载请注明原文地址:https://kaotiyun.com/show/Q68p777K
本试题收录于:
二级C题库NCRE全国计算机二级分类
0
二级C
NCRE全国计算机二级
相关试题推荐
A、 B、 C、 D、 C通过调用友元函数,实现求解n!的算法。sum=5!+4!+3!+2!。
A、 B、 C、 D、 C类指针可以指向派生类对象,但是只能访问基类的数据成员和成员函数。f()作为虚函数,在派生类中被重新定义,可以通过基类指针或者引用来访问基类和派生类中的同名函数。
A、 B、 C、 D、 C根据对二叉树根的访问先后顺序不同,分别称为前序遍历、中序遍历和后序遍历。这3种遍历都是递归定义的,即在其子树中也按照同样的规律进行遍历。下面就是前序遍历方法的递归定义。当二叉树的根不
下列程序的输出结果为:Ohjectid=0Objectid=1请将程序补充完整。#include<iostream>usingnamespaeestd;classPoint{
A、 B、 C、 D、 B算法的空间复杂度一般是指:执行这个算法所需要的存储空间,其中包括算法程序所占的空间、输入的初始数据所占用的存储空间以及算法执行过程中所需要的额外空间。
A、 B、 C、 D、 A由于线性表采用的是顺序存储方式,用存储单元的邻接性体现线性表元素间的一维顺序关系,因此对线性表进行插入和删除运算时,可能需要移动大量的结点,以保持这种物理和逻辑的一致性。对于选项A)
有如下程序:#include<iostream>usingnamespacestd;classtest{private:inta;public:test(){cout<<"c
下列选项中,不属于面向对象程序设计特征的是A)继承性B)多态性C)类比性D)封装性
有如下定义:classMA{intvalue;public:MA(intn=0):value(n){}};MA*ta,tb;其中MA类的对象名标识符是_____
以下选项中合法的用户标识符是
随机试题
NK/T细胞淋巴瘤的特点是
移走原子中某轨道电子所需的最小能量被称为是这个电子的
A.阿拉伯胶B.聚山梨酯C.硫酸氢钠D.二氧化硅E.氯化钠可形成下述乳化膜的乳化剂的是多分子乳化膜
甲有限责任公司成立于2017年1月5日。公司章程规定。股东乙以其名下的一套房产出资。乙于1月7日将房产交付公司,但未办理权属变更手续。5月9日,股东丙诉至人民法院,要求乙履行出资义务。5月31日,人民法院责令乙于10日内办理权属变更手续。6月6日,乙完成办
某国一足球杂志报道说,30年来该国足球甲级联赛的冠军都是通过假球决出来的。该杂志还给出证据说,有一位不愿透露姓名的参赛队员告诉记者,他和他的队友曾收取了20万美元的贿赂,于是他们在一场关键性的比赛中踢假球,最终让另一支球队获胜。但是,该国足球联赛主席则对这
简述美国《国家在危机中:教育改革势在必行》的影响。
Whohasgotapen?
SuggestionsofReadingActivitiesI.Three【T1】______phasesofreading【T1】______—beforereading—inthecourseofreading—a
功夫(Kungfu)是一种典型的中国传统文化,它是一项既活动肌肉又活动大脑的运动。同时,功夫不仅是一项体育运动,也是一种艺术形式。它被用来治病和自卫,而且是一种综合性的人体文化。功夫历史悠久,在中国非常流行。肢体动作只是功夫的外部表现(external
ABriefHistoryofOnlineShoppingA)WhenAmazon.comopenedforbusiness15yearsago,itwasnothingmorethanafewpeoplepack
最新回复
(
0
)