首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
请打开考生文件夹下的解决方案文件proj2,此工程中声明的Array是一个表示数组的类。一个Array对象可以包含多个整型元素。Array的成员说明如下: 成员函数add用于向数组的末尾添加一个元素; 成员函数get用于获取数组中指定位置的元素; 数据成员
请打开考生文件夹下的解决方案文件proj2,此工程中声明的Array是一个表示数组的类。一个Array对象可以包含多个整型元素。Array的成员说明如下: 成员函数add用于向数组的末尾添加一个元素; 成员函数get用于获取数组中指定位置的元素; 数据成员
admin
2018-07-06
38
问题
请打开考生文件夹下的解决方案文件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://jikaoti.com/ti/ctt0FFFM
本试题收录于:
二级C题库NCRE全国计算机二级分类
0
二级C
NCRE全国计算机二级
相关试题推荐
与成员访问表达式p->name等价的表达式是______。
在面向对象方法中,类之间共享属性和操作的机制称为______。
下面程序的执行结果是()。#include”iostream.h”voidmain(){int*p,r;p=newin;*p=20;r=sizeof(*p);cout<<r<<endl
数据结构分为线性结构和非线性结构,带链的队列属于______。
函数swap(arr,n)可完成对arr数组从第1个元素到第n个元素两两交换。在运行调用函数中的语句后,a[0]和a[1]的值分别为【】。a[0]=1;a[1]=2;swap(a,2);
已知枚举类型定义语句为:enumToken{NAME,NUMBER,PLUS=5,MINUS,PRINT=10};则下列叙述中错误的是()。
在进行了任何C++流的操作后,都可以用C++流的有关成员函数检测流的状态,其中只能用于检测刚进行的操作是否失败的函数名是()。
下列运算符中全都可以被友元函数重载的是()。
下列有关数据库的叙述,正确的是()。
在文件操作中,代表以追加方式打开文件的模式是
随机试题
左膈下脓肿最常见的原因是
( )属于设备承揽合同管理应注意解决的问题。
【背景】某建筑物地下室挖土方工程,内容包括:挖基础土方和基础土方回填,基础土方回填采用打夯机夯实,除基础回填所需土方外,余土全部用自卸汽车外运800m至弃土场。提供的施工场地,已按设计室外地坪—0.20m平整,土质为三类土,采取施工排水措施。
M公司向N公司购买材料一批。M公司在付款时发现,发票的正确金额应该是34000元,N公司却误填为43000元。正确的做法是()。
注册会计师保持独立性的含义包括()。
当保单作为礼物赠送时,通常采用()。
贷款风险的预警信号系统中,关于财务状况的信号包括()
幼儿成长档案袋中,幼儿唱歌作品一般用()形式记录。
爱迪生在发明电灯之前做了两千多次实验,有个年轻的记者曾经问他为什么遭遇这么多次失败。爱迪生回答:“我一次都没有失败。我发明了电灯。这只是一段经历了两千步的历程。”爱迪生之所以说“我一次都没有失败”,是因为他把每一次实验都看作()
完成句子。例如:那座桥800年的历史有了那座桥有800年的历史了。从八个小时下午工作到上午
最新回复
(
0
)