首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
请使用菜单命令或直接用VC6打开考生文件夹下的工程proj2,其中有元素类Element和集合类MySet的定义。请在程序中的横线处填写适当的代码,然后删除横线,以实现上述类定义。此程序的输出结果应为: 0 3 5 8 0 3 8 注意:只能在横
请使用菜单命令或直接用VC6打开考生文件夹下的工程proj2,其中有元素类Element和集合类MySet的定义。请在程序中的横线处填写适当的代码,然后删除横线,以实现上述类定义。此程序的输出结果应为: 0 3 5 8 0 3 8 注意:只能在横
admin
2016-06-12
42
问题
请使用菜单命令或直接用VC6打开考生文件夹下的工程proj2,其中有元素类Element和集合类MySet的定义。请在程序中的横线处填写适当的代码,然后删除横线,以实现上述类定义。此程序的输出结果应为:
0 3 5 8
0 3 8
注意:只能在横线处填写适当的代码,不要改动程序中的其他内容,也不能删除或移动“//*********found*********
{}1nclude
#include
usiog namespace std;
#define MaxElement 100
class Element{ //“元素”类
public:
int n;
Element(int i=0):n(i){)
};
class MySet{//“集合”类
Element*element; //指向存储元素的数组的指针
int Size;//数组大小
int counter; //数组中元素的个数
int current; //用于表示扫描位置,及当前被扫描元素在数组中的下标
public:
MySet():element(new Element[1 00]),size(1 00),counter(0),current(0){)
一MySet(){delete[]element;}
void add(Element ele); //向集合中添加一个元素,保持由小到大的顺序。
void remove(Element ele); //删除集合中指定的元素
void scanFirst(){current=0 ;)//将扫描位置定位于首元素
//*********found*********
void scanNext()(_______;)
//将扫描位置定位于下一个元素
Element get()const{return ele-
ment[current];} //返回当前被扫描的元素
bool isEnded()const{return current>=counter;) //如果已经没有更多的元素可扫描了,返回true。
void show(); //显示集合中所有元素
};
void MySet::add(Element ele){
int pos=counter;//pos用于确定元素应插入的位置
while(pos>0){ //从后往前寻找该位置
if(ele.n>element[pos一1].n)
break; //找到应插入的位置,退出循环
//**********found**********
if()return;
//发现相同元素,终止添加过程。
Pos一一;
}
if(counter>=size){ //如果没有足够空间,扩充空间(增加100个元素的容量)
Element*tmp=element; //tmp指向原来的数组
// **********found**********
element=____________;
//申请一个新的数组,容量扩大100个元素的容量
for(int i=0;i
element
=tmp
;
size+=i00;
delete[]tmp;
}
for(int i=counter;i>pos;
i一一)element
=element[i一1];
//后移相关元素,腾出存放新元素的空间
element[pos]=ele,//插入新元素
counter++;
}
void MySet::show()f
scanFirst(); //扫描位置定位于首元素
while(!isEnded()){
cout<
//**********found**********
; //扫描定位于下一个元素
}
cout<
}
void MySet::remove(Element ele){
int pos=counter一1; //pos用于确定要删除的元素的位置
while(pos>=0){//从后往前寻找该位置
if(ele.n>elen~nt[pos].n)return;
//集合中没有该元素,终止删除过程。
if(ele.n==element[pos].n)
break; //找到删除的元素,退出
循环。
pos一一;
}
if(pos<0)return;//集合中没有该元素,终止删除过程。
for(int i=pos;i
element
=element[i+1]; //删除该元素,后面的元素顺序前移。
counter一;
if(counter+100<=size)( //如果未使用的存储单元超过100,缩减存储空间,减少i00个单元
Element*tmp=element;
element=new Element[size—i00];
for(int i=0;i
element
=tmp
;
Size一=100;
delete[]tmp;
}
}
int main(){
MySet set,
set.add(Element(3));
set.add(Element(8));
set.add(Element(5));
set.add(Element(0));
set.show();
set.remove(Element(5));
set.remove(Element(4)),
set.add(Element(8));
set.show();
return 0,
}
选项
答案
(1)++current (2)ele.n==element[pos一1].n (3)new Element[size+100] (4)scanNext()
解析
本题考查自增运算符、相等运算符,动态内存分配、成员函数的使用。
【解题思路】
(1)主要考查考生对数组和自增运算符的掌握情况,扫描数组元素,将扫描位置定位到下一个元素,需要将下标加1,使用自增运算符。
(2)主要考查考生对数组元素的访问和比较运算符的掌握,pos初值为数组元素个数,所以访问element元素使用pos一1,避免访问数组越界;另外需要判断插入元素与当前元素是否相等来决定程序是否返回,使用相等运算符。
(3)主要考查考生对动态内存分配的掌握,题意需要申请一个新的数组,并将当前数组容量size扩大100个,所以答案为new Element[size+loo]。
(4)主要考查考生对类成员函数的掌握,show函数用来输出数组的所有元素,所以从首元素开始一次输出,输出一个元素需要将扫描定位到下一个元素,对应于前面的scan.First(),使用成员函数scanNext()最合适不过了。
转载请注明原文地址:https://kaotiyun.com/show/6iNp777K
本试题收录于:
二级C题库NCRE全国计算机二级分类
0
二级C
NCRE全国计算机二级
相关试题推荐
如果表达式x*y+z中,“*”是作为友元函数重载的,“+”是作为友元函数重载的,则该表达式还可为
对于下面的程序,说法正确的是 #include<iostream.h> voidmain() {intx=3,y=4,z=2; if(X=y+z)cout<<"x=y+Z"; elsecout<<"x!=y+Z";}
关于友元的概念错误的是
设以下变量均为int类型,则值不等于7的表达式是
假定用户没有给一个名为MyClass的类定义析构函数,则系统为其定义的默认析构函数首部形式为【】。
下列关于静态数据成员的描述中,正确的是()。
以于下面定义的类MyClass,在函数f()中将对象成员n的值修改为50的语句应该是()。classMyClass{public:MyClass(intx){n=x;
下列叙述中,正确的是()。
若已定义的函数有返回值,则以下关于该函数调用的叙述中错误的是
以下哪个不是C++语言中的有效标识符()。
随机试题
企业内部良好的工作环境是培植企业精神的基础,也是弘扬企业精神的重要因素。()
对高血压脑出血病人急性期处理的最重要的环节是
腹外疝的发病基础是
小张取得一张四通有限公司开出的可背书转让汇票,该票据承兑行是上海长宁区工商银行。小张到青岛出差时不慎将该汇票丢失,立即向法院申请公示催告。法院经审查后发出催告,公告期为70天。到第80天,仍无人申报权利,该法院于是判决除去原票据上的权利,终结公示催告程序。
关于版权保护,下列哪一选项体现了《与贸易有关的知识产权协议》对《伯尔尼公约》的补充?
设备监理单位是指具有()资格并取得“设备监理单位资格证书”的从事重要设备监理业务的组织。
某企业为增值税一般纳税企业,适用的增值税率为17%。本月“应收账款”期初余额为117000元,本月收回应收账款70200元,“应收账款”期末余额为93600元;“库存商品”账户期初余额为100000元,本月完工人库商品为90000元;本
申请设立除会计师事务所以外的代理记账机构,应当经所在地的()批准,并领取由财政部统一印制的代理记账许可证书。
甲公司于2011年1月1日发行5年期、一次还本、分期付息的公司债券,每年12月31日支付利息。该公司债券票面利率为5%,面值总额为300000万元,发行价格总额为313347万元;支付发行费用120万元,发行期间冻结资金利息为150万元。假定该公司每年年末
A、HeisrememberedB、TorememberC、WhilerememberingD、AlthoughrememberedD句意:尽管为人所铭记的主要还是他发明电话,但是亚历山大·格拉汉姆·贝尔一生都在帮助聋哑人。主语是人,谓语
最新回复
(
0
)