首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
请使用VC6或使用【答题】菜单打开考生文件夹proj3下的工程proj3,其中包含了类Integers和主函数main的定义。一个Integers对象就是一个整数的集合,其中包含0个或多个可重复的整数。成员函数add的作用是将一个元素添加到集合中,成员函数
请使用VC6或使用【答题】菜单打开考生文件夹proj3下的工程proj3,其中包含了类Integers和主函数main的定义。一个Integers对象就是一个整数的集合,其中包含0个或多个可重复的整数。成员函数add的作用是将一个元素添加到集合中,成员函数
admin
2016-08-19
58
问题
请使用VC6或使用【答题】菜单打开考生文件夹proj3下的工程proj3,其中包含了类Integers和主函数main的定义。一个Integers对象就是一个整数的集合,其中包含0个或多个可重复的整数。成员函数add的作用是将一个元素添加到集合中,成员函数remove的作用是从集合中删除指定的元素(如果集合中存在该元素),成员函数sort的作用是将集合中的整数按升序进行排序。请编写这个sort函数。此程序的正确输出结果应为:
5 28 2 4 5 3 2 75 27 66 31
5 28 2 4 5 3 2 75 27 66 31 6
5 28 2 4 5 3 2 75 27 66 3l 6 19
5 28 4 5 3 2 75 27 66 31 6 19
5 28 4 5 3 2 75 27 66 31 6 19 4
2 3 4 4 5 5 6 19 27 28 31 66 75
要求:
补充编制的内容写在“//********333********”与“//********666********”之间。不得修改程序的其他部分。
注意:相关文件包括:main.cpp、Integers.h。
程序最后调用writeToFile函数,使用另一组不同的测试数据,将不同的运行结果输出到文件out.dat中。输出函数writeToFile已经编译为obj文件。
1 //Integers.h
2 #ifndef INTEGERS
3 #define INTEGERS
4
5 #include
6 using namespace std;
7
8 const int MAXELEMENTS=100;
9 //集合最多可拥有的元素个数
10
11 class Integers{
12 int elem[MAXELEMENTS];
13 //用于存放集合元素的数组
14 int counter;
15 //用于记录集合中元素个数的计数器
16 public:
17 Integers():counter(0){}
18i //创建一个空集合
19 Integers(int data[],int size);
20 //利用数组提供的数据创建一个整数集合
21 void add(int element);
22 //添加一个元素到集合中
23 void remove(int element);
24 //删除集合中指定的元素
25 int getCount()const{return count-er;}
26 //返回集合中元素的个数
27 int getElement(int i)const{return elem
;)
28 //返回集合中指定的元素
29 void sort();
30 //8集合中的整数按由小到大的次序进行排序
31 void show()const;
32 //显示集合中的全部元素
33 };
34 void writeToFile(const char*path);
35 #endif
1 //main.cpp
2 #include"Integers.h"
3 #include
4
5 Integers::Integers(int data[],int size):counter(0){
6 for(int i=0;i
);
7 }
8
9 void Integers::add(int element){
10 if(counter
11 elem[counter++]=element;
12 }
13
14 void Integers::remove(int element){
15 int j;
16 for(j=counter-1;j>=0;j--)
17 if(elem[j]==element)break;
18 for(int i=j;i
19 elem
=elem[i+1];
20 counter--;
21 }
22
23 void Integers::sort(){
24 //********333********
25 //********666********
26 }
27
28 void Integers::show()const{
29 for(int i=0;i
30 cout<
31 cout<
32 }
33 int main(){
34 int d[]={5,28,2,4,5,3,2,75,27,66,31);
35 Integers S(d,11);s.show();
36 s.add(6); s.show();
37 s.add(1 9); s.show();
38 s.remove(2); s.show();
39 s.add(4); s.show();
40 s.SOrt(); s.show();
41 writeToFile(" ");
42 return 0;
43 }
选项
答案
1 for(int i=0;i
i ; j--) //从最后一位到i到前一位遍历elem 3 if(elem[i]>elem[j])//如果elem[i]大于elem[j],则两值替换 4 { 5 int temp:elem[i];//定义整形变量temp并赋值为elem[i]; 6 elem[i]=elem[j];//给elem[i]赋值elem[i] 7 elem[j]=temp;//给elem[j]赋值temp 8 }
解析
主要考查考生对排序算法的掌握,要排序的数组为elem,元素个数为counter,在这里使用下标i和j进行比较,当elem
>elem[j]时,数组元素通过中间变量temp进行交换。
转载请注明原文地址:https://kaotiyun.com/show/a4Np777K
本试题收录于:
二级C题库NCRE全国计算机二级分类
0
二级C
NCRE全国计算机二级
相关试题推荐
需求分析最终结果是产生()。
函数重载是指()。
下面程序的输出结果是#include<iostream.h>#include<string.h>voidmain(){charp1[10],P2[10];strcpy(p1,"abc");s
如果友元函数重载一个运算符时,其参数表中没有任何参数则说明该运算符是
在下面的类定义中,错误的语句是()。classSample{public:Sample(intval);//①~Sample()://②private:
下面这个程序段的时间复杂度是()。for(i=1;i<n;i++){y=y+1;for(j=0;j<=(2*n);j++)X++;}
在C++语言的面向对象程序设计框架中,【】是程序的基本组成单元。
下列for语句的循环次数为【】。for(inta=0,b=1;b&&a<5;a++);
C++语言中while循环和do-while循环的主要区别是
在下列枚举符号中,用来表示“相对于当前位置”文件定位方式的是
随机试题
在社会服务机构的资金来源中,很大一部分来自政府。政府的资助方式一般通过购买服务和()来实现。
RDW与MCV同时增加最常见于
A.肾上腺皮质功能减退B.Cullen征C.多发性神经纤维瘤D.血色病E.Greyv-ruiner征腹部和腰部不规则的斑片状色素沉着
治疗筋脉挛急疼痛的药物,大多是何味药
Ⅰ类和Ⅱ类建设项目,分别根据其对地下水环境的()、建设项目所处区域的环境特征及其环境影响程度划定评价工作等级。
2017年9月5日,某事业单位购入一台不需要安装的检测专用设备,设备价款为60000元,由财政直接支付。下列会计处理中正确的是()。
甲公司的开户银行为P银行,2016年4月1日,甲公司委派员工张某携带一张公司签发的出票日期为2016年4月1日,金额和收款人名称均空白的转账支票赴乙公司洽谈业务,为支付货款,张某在支票上填写金额15万元后支付乙公司。当日,为偿还所欠丙公司劳务费,乙公司将支
20世纪,国际社会为维持和平进行了不懈努力。下列表述正确的是()。
教育部部长袁贵仁在全国教育工作会议上表示,2015年将推进招生计划管理改革,新增()全部安排给高等教育资源相对缺乏、升学压力较大的中西部和人口大省。
下列有关曲辕犁的表述正确的是()①曲辕犁早在中国汉代即已使用了②曲辕犁在中国出现至少比欧洲早一千多年③我国古代的农业工具和农耕技术曾长期居世界领先地位④处于“蒸汽时代”的欧洲农业技术革新,滞后于同时代工业的发
最新回复
(
0
)