首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
使用VC6打开考生文件夹proj2下的工程Proj2,其中有元素类Element和队列类Queue的定义。请在程序中的横线处填写适当的代码,然后删除横线,以实现上述类定义。此程序的输出结果应为: 3 8 5 0 5 0 7 注意:只
使用VC6打开考生文件夹proj2下的工程Proj2,其中有元素类Element和队列类Queue的定义。请在程序中的横线处填写适当的代码,然后删除横线,以实现上述类定义。此程序的输出结果应为: 3 8 5 0 5 0 7 注意:只
admin
2017-07-04
67
问题
使用VC6打开考生文件夹proj2下的工程Proj2,其中有元素类Element和队列类Queue的定义。请在程序中的横线处填写适当的代码,然后删除横线,以实现上述类定义。此程序的输出结果应为:
3 8 5 0
5 0 7
注意:只能在横线处填写适当的代码,不要改动程序中的其他内容。
#include
#include
#include
using namespace std;
#define MaxLength i 00
class Element { //“元素”类
public:
int n;
Element(int i=0):n(i){)
};
class Queue{ //“队列”类
Element * element;
//指向存储元素的数组的指针
int tail;//队尾元素的下标
public:
Queue():element(new Element
[100]),tail(一1){}
一Queue(){delete[]element;}
void push(Element ele); //在队列
尾端添加一个元素
Element pop();
//在队列首端删除一个元素,返回被删元素
Element front()const{return element[0];
//返回队首元素,但不从队列中删除该元素
//******found******
int size()const{ return
(_______);}//返回元素个数
void show()const,
//显示集合中所有元素
};
void Queue::push(Element ele){
if(tail==MaxLength一1)
return;//空间满,不做任何处理
//******found******
________;
}
Element Queue::pop(){
if(Size()==0)exit(1);
//队列空,不做任何处理
Element tmp=element[0];
for(int i=0;i
element
=element[i+1];
//******found******
__________;
return tmp;
}
VOid Queue::show ()const {
//******found******
for(_________)
cout<
.n<<’’;
cout<
}
int main(){
Queue q;
q.push(3);
q.push(8);
q.push(5);
q.push(0);
q.show();
q.pop();
q.pop();
q.push(7);
q.show();
return 0;
}
选项
答案
(1)tail +1 (2)element[++tail] =ele (3)tail-- (4)int i=0;i <=tail ; i++
解析
题意定义了Element类,表示队列中的元素,它包含一个成员n,表示元素的值;定义了Queue类,表示队列,它包含两个成员:element是动态分配的一个数组,每个元素都是Element类型;tail表示队列尾部的下标值,指向element数组的最后一个元素,当数组为空时,tail的值为一1,所以初始化为一1;另外Queue类还定义了若干成员函数:构造函数为ele.ment数组动态分配100个元素空间,初始化tail为一1;析构函数释放element;push()函数向队列中添加一个新元素ele,即将形参ele存放到数组尾部,并将tail自增1;pop()函数将element数组的第一个元素(下标为0)从数组中删除(采用移动后续所有元素的方式),并作为函数返回值返回;front()函数返回队列首元素;size()函数返回当前element数组的元素个数;show()函数将element数组中的元素的n值输出,由上面的分析,补充代码如下:
(1)size()函数返回element数组的元素个数,tail的值是element数组的最后一个元素的下标,所以返回tail+l即可。
(2)push()函数将参数ele插入到队列的尾部,即将ele保存到element数组下标为(tail+1)的位置:element[++tail]=ele;
(3)poP()函数将element数组的首元素保存到tmp变量中,然后遍历element数组,将下标从1开始的元素逐个赋给前一个元素,再把tail的值自减1,tail--;
(4)show()函数需要遍历element数组,然后将元素的n值输出,遍历下标的变量需要定义为i,i初值从0开始,直到i等于最后一个元素的下标,即tail。int i=0;i<=tail;i++
转载请注明原文地址:https://kaotiyun.com/show/uLAp777K
本试题收录于:
二级C题库NCRE全国计算机二级分类
0
二级C
NCRE全国计算机二级
相关试题推荐
有如下程序 main() {int n=9; while(n>6)<n--; cout<<n<<endl;} } 该程序段的辅出结果是
下列程序的运行结果是 main() {int a=2,c=5; cout<<"a="<<a<<"b="<<c<<endl }
下列程序完成从文件读取文件显示的同时写入第二个文件,则在程序中划线部分应该出现的语句是【 】。#include<iostream,h>#include<fstream,h>voidmain(){fstreamfilel,file2
数据库管理最本质的特点是实现数据的共享。为了实现数据的共享,保证数据的独立性、完整性和安全性,需要有一组软件来管理数据库中的数据,处理用户对数据库的访问,这组软件称为【 】。
定义静态成员函数的主要目的是
设有如下定义 struct ss { char name[10]; int age; char sex; }std[3], * p=std; 下面各输入语句中错误的是
设单链表中结点的结构为(data,link)。已知指针q所指结点是指针p所指结点的直接前驱,若在*q与*p之间插入结点*s,则应执行下列哪一个操作?( )。
若需要利用形参直接访问实参,则应把形参变量说明为( )参数。
设有如图所示的二叉树则对该二叉树后序遍历的结果是
下列字符串中,正确的C++标识符是()。
随机试题
AfewyearsagoanAmericancampaignerwroteabookinwhichhesetthemainpointsofhisfascinatingcrusade(改革运动)-toabolish
下列哪项是燥邪犯肺证与肺阴虚证的鉴别要点
肋骨骨折后,保持呼吸道通畅,首选
患者,女性,40岁,两日来右后牙夜痛不能眠。3个月来右侧下后牙咬物不适,冷水引起疼痛。近两日来,夜痛影响睡眠,并引起半侧头、面和右耳后部痛,分不清痛牙位置。检查时见右侧上、下第一、二磨牙均有邻面深龋洞。根据患者疼痛的性质,患牙最可能的诊断是
背景资料某企业承建一多功能现代化商务综合大厦,地上46层,地下3层,全现浇钢筋混凝土框架一剪力墙结构,主体结构采用泵送混凝土等新技术。建筑物周边都十分接近规划用地红线,周边建筑及地下管线对因工程基坑开挖引起的地层变形移动影响十分敏感,且基坑北面临近地铁。
上海市高级人民法院审判员职务的撤销,由()决定。
发明专利的有效期限的起算点为()。
下列关于聚众斗殴罪的说法,正确的是()。
Moreandmoreofusare(1)_____theTVnetworks.That’snotnews,ofcourse;therehavebeencountlessstoriesontheir(2)____
A、 B、 C、 B
最新回复
(
0
)