首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
请打开考生文件夹下的解决方案文件proj2,此工程中声明的Array是一个表示数组的类。一个Array对象可以包含多个整型元素。Array的成员说明如下: 成员函数add用于向数组的末尾添加一个元素; 成员函数get用于获取数组中指定位置的元素; 数据成员
请打开考生文件夹下的解决方案文件proj2,此工程中声明的Array是一个表示数组的类。一个Array对象可以包含多个整型元素。Array的成员说明如下: 成员函数add用于向数组的末尾添加一个元素; 成员函数get用于获取数组中指定位置的元素; 数据成员
admin
2018-07-06
36
问题
请打开考生文件夹下的解决方案文件proj2,此工程中声明的Array是一个表示数组的类。一个Array对象可以包含多个整型元素。Array的成员说明如下:
成员函数add用于向数组的末尾添加一个元素;
成员函数get用于获取数组中指定位置的元素;
数据成员a表示实际用于存储数据的整型数组;
数据成员size表示数组的容量,数组中的元素个数最多不能超过size;
数据成员num表示当前数组中的元素个数。
SortedArray是A11ray的派生类,表示有序数组。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
;
return0;
}
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<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);
return0;
}
选项
答案
(1)a[Bum]=e; (2)Array(S) (3)a[j]=a[j-1] (4)a[i]=e
解析
(1)考查的是虚函数virtual void add(inte)的定义,即添加一个整型数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/5AAp777K
本试题收录于:
二级C题库NCRE全国计算机二级分类
0
二级C
NCRE全国计算机二级
相关试题推荐
与成员访问表达式p->name等价的表达式是______。
数据的基本单位是______。
有如下程序:#include<iostream>usingnamespacestd;classVAC{public;intf()const{return3;}intf(){return5;}
下列运算符函数中肯定不属于类FunNumber的成员函数的是()。
数据的存储结构是指()。
设有以下说明和定义:#include<iostream.h>Voidmain(){typedefunion{longi;intk[5];charc;}DATE;struct
线性表的顺序存储结构和线性表的链式存储结构分别是
有下列语句序列:intk=0;do{k+=5;cout<<’$’;}while(k<19);while(k-->0)cout<<’*’;执行上面的语句序列输出字符“$”和“*”的个数
虚基类说明格式如下:slass派生类名【】<继承方式><基类名>。
已知数据表A中每个元素距其最终位置不远,为节省时间,应采用的算法是
随机试题
下列中常有高雌激素或雄激素症状的一类卵巢癌是
导致心肌炎最主要的病原是
2011年1月,甲、乙、丙、丁、戊共同出资设立A有限合伙企业(简称A企业),从事产业投资活动。其中,甲、乙、丙为普通合伙人,丁、戊为有限合伙人。丙负责执行合伙事务。2011年2月,丙请丁物色一家会计师事务所,以承办本企业的审计业务。、丁在合伙人会议上提议聘
下列各事项中,会计上和税法上核算不—致,需要进行纳税调整的有()。
历史文化名城的布局、环境、历史风貌等遭到严重破坏的,由()撤销其历史文化名城称号。
课外、校外教育活动的主要组织形式是()
对39种食物中是否含有甲、乙、丙三种维生素进行调查,结果如下:含甲的有17种,含乙的有18种,含丙的有15种,含甲、乙的有7种,含甲、丙的有6种,含乙、丙的有9种,三种维生素都不含的有7种,则三种维生素都含的有多少种?()
新经济政策的实质是()。
一台设置为IP地址自动获取的主机H接入到仅有一台服务器的局域网络中,在H上截获到如表4—2所列的两个以太网数据帧前48个字节的十六进制报文,请参考表中的数据回答如下问题:(1)主机H采用何种方式获得IP地址,一般需要哪几个报文过程才能完成?(2)主机H
基本以下题干,回答问题过新年,小明家吃团圆饭,7个家庭成员——小明、妹妹、阿姨、爷爷、奶奶、妈妈和爸爸坐在一长方形桌子旁边。3个人坐在桌子的一边,另3个人坐在桌子的另一边,并且彼此相对,第7个人坐在桌子的头部,没有人在桌子的尾部。妹妹总是坐在桌子
最新回复
(
0
)