首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
请打开考生文件夹下的解决方案文件proj2,此工程包含有一个源程序文件proj2.cpp,其中定义了Stack类和ArrayStack类。 Stack是一个用于表示数据结构“栈”的类,栈中的元素是字符型数据。Stack为抽象类,它只定义了栈的用户接口,如下
请打开考生文件夹下的解决方案文件proj2,此工程包含有一个源程序文件proj2.cpp,其中定义了Stack类和ArrayStack类。 Stack是一个用于表示数据结构“栈”的类,栈中的元素是字符型数据。Stack为抽象类,它只定义了栈的用户接口,如下
admin
2018-11-11
52
问题
请打开考生文件夹下的解决方案文件proj2,此工程包含有一个源程序文件proj2.cpp,其中定义了Stack类和ArrayStack类。
Stack是一个用于表示数据结构“栈”的类,栈中的元素是字符型数据。Stack为抽象类,它只定义了栈的用户接口,如下所示:
公有成员函数功能
push 入栈:在栈顶位置添加一个元素
pop 退栈:取出并返回栈顶元素
ArTayStack是Stack的派生类,它实现了Stack定义的接口。ArrayStack内部使用动态分配的字符数组作为栈元素的存储空间。数据成员maxSize表示的是栈的最大容量,top用于记录栈顶的位置。成员函数push和pop分别实现具体的入栈和退栈操作。
请在程序中的横线处填写适当的代码,然后删除横线,以实现上述功能。此程序的正确输出结果应为:
a,b,c
c,b,a
注意:只在指定位置编写适当代码,不要改动程序中的其他内容,也不要删除或移动“//****found****”。
//proj2.cpp
#include<iostream>
using namespace std;
class Stack{
public:
virtual void push(char c)=0;
virtual char pop( )=0;
};
class ArrayStack:public Stack{
char*P;
int maxSize;
int top;
public:
ArrayStack(int s)
{
top=0;
maxSize=s;
//********found********
p=_______;
}
~ArrayStack( )
{
//********found********
_______;
}
void push(char c)
{
if(top==maxSize){
cerr<<"Overflow!\n";
return;
}
//********found********
_______;
top++;
}
char pop( )
{
if(top==0){
cerr<<"Underflow!\n";
return’\0’;
}
top--;
//********found********
_______;
}
};
void f(Stack&sRef)
{
char ch[ ]={’a’,’b’,’c’};
cout<<ch[0]<<","<<ch[1]<<","<<ch[2]<<endl;
sRef.push(ch[0]);sRef.push(ch[1]);sRef.push(ch[2]);
cout<<sRef.pop( )<<",";
cout<<sRef.pop( )<<",";
cout<<sRef.pop( )<<endl;
}
int main( )
{
ArrayStack as(10);
f(as);
return0;
}
选项
答案
(1)new char[s] (2)delete[ ]p (3)p[top]=c (4)return p[top]
解析
(1)主要考查的是ArrayStack类的构造函数,在函数中要为p申请S个char型空间,应使用语句p=new char[S];。
(2)主要考查析构函数,使用delete语句释放指针,即delete[ ]p;。
(3)主要考查push函数,top表示栈顶元素下标,添加的数据放到栈顶,因此使用语句p[top]=c;。
(4)主要考查pop函数,输出栈顶数据,top表示栈顶元素下标,因此使用语句return p[top];。
转载请注明原文地址:https://www.kaotiyun.com/show/KwAp777K
本试题收录于:
二级C题库NCRE全国计算机二级分类
0
二级C
NCRE全国计算机二级
相关试题推荐
函数inttest(inta,intb=1,intc=0),下列调用不合法的个数是test(0);test(0,0);test();test(0,0,0);
若将一个二元运算符重载为类的成员函数,其形参个数应该是______个。
假定MyClass为一个类,则执行MyClassab(2),*p;语句时,自动调用该类构造函数()次。
友元类的所有成员函数都是另一个类的【】函数。
下列数据结构中,能用二分法进行查找的是()。
在一个容量为25的循环队列中,若头指针front=15,尾指针rear=6,则该循环队列中共有______个元素。
在计算机中,算法是指
冒泡排序算法在最好的情况下的元素交换次数为______。
以下不使用线性结构表示实体之间联系的模型的是()。
随机试题
下列双代号网络图中,非关键工作有()。
场景中项目施工成本计划编制的方法属于()。施工成本计划作为成本控制的依据,需包括的内容之一是()。
关于疏散楼梯间设置的做法,错误的是()。
下列属于通用凭证的有()。
下列对法所作的分类中,属于根据法的内容进行分类的是()。
吴菊萍因为义举,公司奖励了她20万,但是就没有后续报道了。有人说她应该把钱捐出来。否则影响她的形象.你怎么看?
在考生文件夹下,打开文档word2.docx,按照要求完成下列操作并以该文件名(word2.docx)保存文档。【文档开始】姓名数学外语政治语文平均成绩王立98878987
在考生文件夹下,打开文档WORD2.DOCX,按照要求完成下列操作并以该文件名(WORD2.DOCX)保存文档。【文档开始】姓名数学外语政治语文平均成绩王立9887898
Itwillbe______tomorrow.
Bigcitestodayareconfrontedwithveryseriousproblems.Transportisa【C1】______difficulty:someplannersbelievein【C2】_____
最新回复
(
0
)