首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
请使用“答题”菜单或使用VC6打开考生文件夹proj3下的工程proj3,其中包含了类IntegerSet和主函数main的定义。一个IntegerSet对象就是一个整数的集合,其中包含0个或多个无重复的整数;为了便于集合操作,这些整数按升序存放在成员数组
请使用“答题”菜单或使用VC6打开考生文件夹proj3下的工程proj3,其中包含了类IntegerSet和主函数main的定义。一个IntegerSet对象就是一个整数的集合,其中包含0个或多个无重复的整数;为了便于集合操作,这些整数按升序存放在成员数组
admin
2015-06-27
38
问题
请使用“答题”菜单或使用VC6打开考生文件夹proj3下的工程proj3,其中包含了类IntegerSet和主函数main的定义。一个IntegerSet对象就是一个整数的集合,其中包含0个或多个无重复的整数;为了便于集合操作,这些整数按升序存放在成员数组elem的前若干单元中。成员函数add将一个元素添加到集合中(如果集合中不存在该元素),成员函数remove从集合中删除指定的元素(如果集合中存在该元素)。请编写成员函数remove。在main函数中给出了一组测试数据,此时程序的正确输出结果应为:
23452728316675
234562728316675
23456192728316675
3456192728316675
3456192728316675
要求:
补充编制的内容写在//**********333**********与//**********666**********两行之间。不得修改程序的其他部分。
注意:
程序最后已经将结果输出到文件out.dat中。输出函数WriteToFile已经编译为obj文件,并且在本程序中调用。
#include"IntegerSet.h"
#include
IntegerSet::IntegerSet(intdata[],intsize):counter(0){
for(inti=0;i
add(data
);
}
voidIntegerSet::add(intelement){
intj;
//从后往前寻找第一个小于等于element的元素
for(j=counter;j>0;j--)
if(element>=elem[j-1])
break;
//如果找到的是等于element的元素,说明要添加的元素已经存在,直接返回
if(j>0)
if(element==elem[j-1])return;
//如果找到的是小于element的元素,j就是要添加的位置
//该元素及其后面的元素依次后移,腾出插入位置
for(intk=counter;k>j;k--)elem[k]=elem[k—1];
elem[j]=element;//将element插入到该位置
counter++;//计数器加1
}
voidIntegerSet::remove(intelement){
//********333********
//********666********
}
voidIntegerSet::show()const{
for(inti=0;i
cout<
cout<
}
intmain(){
intd[]={5,28,2,4,5,3,2,75,27,66,31);
IntegerSets(d,11);S.show();
s.add(6);s.show();
s.add(19);s.show();
s.remove(2);s.show();
s.add(4);s.show();
WriteToFile("C:\\test\\");
return0;
}
roj3\IntegerSet.h
{}ifndefINTEGERSET
#defineINTEGERSET
#include
usingnamespacestd;
constintMAXELEMENTS=100;//集合最多可拥有的元素个数
classIntegerSet{
intelem[MAXELEMENTS];//用于存放集合元素的数组
intcounter;//用于记录集合中元素个数的计数器
public:
IntegerSet():counter(0){}//创建一个空集合
IntegerSet(intdata[],intSize);
//利用数组提供的数据创建一个整数集合
voidadd(intelement);//添加一个元素到集合中
voidremove(intelement);//删除集合中指定的元素
intgetCount()const{returncounter;}//返回集合中元素的个数
intgetElement(inti)const{returnelem
;}//返回集合中指定的元素
voidshow()const;
};
voidWriteToFile(char*);
#endif
选项
答案
intj,k; for(j=0;j
=counter||element!=elem[j]) { return; } for(k=j;k
解析
主要考查考生对对象处理的掌握,函数remove的功能是将IntegerSet类中数组成员elem包含的值等于element的元素删除。由add函数可知,数组elem的元素添加进来时是有序的,所以首先从前往后遍历数组,查找第一个不小于element的元素,如果元素下标不小于counter或者找到的元素不等于element,说明该数组中没有值等于element的元素,返回即可;否则说明元素下标合法且元素值等于element,设该元素下标为j,将该元素后面的所有元素依次前移一位,相当于删除了elem[j],最后需要更新counter值。
转载请注明原文地址:https://jikaoti.com/ti/FiE0FFFM
本试题收录于:
二级C题库NCRE全国计算机二级分类
0
二级C
NCRE全国计算机二级
相关试题推荐
将小写字母n赋值给字符变量one_char,正确的操作是______。
程序的三种基本控制结构的共同特点是______。
若已定义,以下fun函数的功能是:在第一个循环中给前10个数组元素依次赋1、2、3、4、5、6、7、8、9、10;在第二个循环中使a数组前10个元素中的值对称折叠,变成1、2、3、4、5、5、4、3、2、1。请填空。fun(inta[])
以下程序的输出结果是【】。#include<iostream.h>voidmain(){int*p;p=newint;*p=200;cout<<*p;
下述有关构造函数的说法,不正确的是()。
以下函数模板max的功能是返回数组a中最大元素的值。请将横线处缺失部分补充完整。template<typenameT>Tmax(Ta[],intn){Tm=a[0];for(inti=1;i<n;i++)
以下程序段的输出结果是______。#include<iostream.h>voidmain(){intx[]二{9,7,5,3,1),y=0,j,*p=&x[2];for(j=0;i<3;j+
若有函数func(par1,par2+par3,(par4,par5)):在调用该函数时,实参的个数是______。
在不同文件的函数中,对非静态全局变量的引用要加的关键字是()。
在C++中,打开一个文件,就是将这个文件与一个()建立关联;关闭一个文件,就是取消这种关联。
随机试题
秦汉时期,为了灵活管理少数民族地区,在郡下设立的相当于县的行政区域是()
A.头痛、腰痛、眼眶痛B.高热、惊厥、休克、呼吸衰竭C.心悸、气促、相对缓脉D.高热、瘀斑、休克、呼吸衰竭E.发热、皮疹、脾大
A.5分钟B.15分钟C.30分钟D.60分钟E.120分钟《中国药典》中规定,下列各片剂的崩解时限分别为糖衣片
A、吗啡B、哌替啶C、喷他佐辛D、纳洛酮E、可待因可用于制备人工冬眠合剂的药物是
因债务人怠于行使到期债权,对债权人造成损害的,债权人可以向人民法院请求以( )的名义代位行使债务人的债权,但该债权专属于债务人自身的除外。
公安机关职责的特点有()。
党和国家政府制定了一系列惠民政策,却没有得到很好的执行,请你谈谈对此事的看法。
A、Westillhave40minutesleftbeforedeparture.B、Westillhave20minutesleftbeforedeparture.C、Westillhave50minutesl
WhatIworriedaboutwas______.
A、Practicingconstantly.B、Workingbyoneself.C、Learningbydoing.D、Usingprovenmethods.B短文最后一句说,罗伯茨认为,一个人学习全新的东西时,最好是找个没人的地
最新回复
(
0
)