首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
请打开考生文件夹下的解决方案文件proj2,此工程中声明的Array是一个表示数组的类。一个Array对象可以包含多个整型元素。Array的成员说明如下: 成员函数add用于向数组的末尾添加一个元素; 成员函数get用于获取数组中指定位置的元素; 数据成员
请打开考生文件夹下的解决方案文件proj2,此工程中声明的Array是一个表示数组的类。一个Array对象可以包含多个整型元素。Array的成员说明如下: 成员函数add用于向数组的末尾添加一个元素; 成员函数get用于获取数组中指定位置的元素; 数据成员
admin
2018-07-06
68
问题
请打开考生文件夹下的解决方案文件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全国计算机二级
相关试题推荐
友元类的所有成员函数都是另一个类的______。
执行下列语句后,输出结果为()。cout.put(‘s’);cout<<‘c’<<‘a’;
创建对象数组时,对数组的每一个元素都将调用一次构造函数,如果没有显式给出数组元素的初值,则调用默认构造函数,下列程序涉及对象数组的创建和单个对象的创建,其输出结果是______。#include<iostream>usingname
有如下程序:#include<iostream>usingnamespacestd;classAA{intn;public:AA(intk):n(k){}
软件需求分析阶段的工作,可以分为4个方面:需求获取、需求分析、编写需求规格说明书以及()。
冒泡排序算法在最好的情况下的元素交换次数为______次。
用树型结构表示实体之间联系的模型是()。
如果使用数组名称为函数参数,形实结合时,传递的是______。
在数据库设计中,将E-R图转换为关系模式的过程属于()。
数据库管理最本质的特点是实现数据的共享。为了实现数据的共享,保证数据的独立性、完整性和安全性,需要有一组软件来管理数据库中的数据,处理用户对数据库的访问,这组软件称为______。
随机试题
头痛眩晕,昏厥,呕血,见于
盒中装着标有数字1,2,3,4的乒乓球各2个,从盒中任意取出3个球,求下列事件概率.(1)A={取出的3个球上最大的数字是4}.(2)B={取出的3个球上的数字互不相同}.
钙拮抗剂降压治疗的特点包括
A.肺性脑病B.上腹胀痛、少尿C.偶尔发生的下肢轻微水肿D.气胸E.舒张期奔马律上述症状或体征出现于下列哪一时期慢性肺心病心力衰竭
下列物质中,属于酚类物质的是()。
根据《水工建筑物地下开挖工程施工规范》SL378—2007,下列关于水利水电工程土石方开挖施工的说法,错误的是()。
符合混凝土运输要求的有()。
阅读材料,回答问题。材料一下面是巴黎和会上五个国家的代表说的话:①我有的是钱,你们都听我的。②借给我钱可以,想当老大你还嫩了点儿!③应该把那条腿也打断,叫他永远也爬不起来!④等老子伤好了再跟你们算账!⑤老兄,你占的便宜够大了,悠着点儿吧。材料二
下列几个地区中,城市卫生机构比农村卫生机构少的是()。
在报表中要添加标签控件,应使用
最新回复
(
0
)