c++栈 编写一个类实现简单的栈

chuxuezheageweibangbangmangha编写一个类,实现简单的栈操作:元素入栈,读出栈顶元素值,退栈,判断栈顶元素是否为空。如果栈溢出,程序终止。栈的数... chu xue zhe a
ge wei bang bang mang ha

编写一个类,实现简单的栈操作:元素入栈,读出栈顶元素值,退栈,判断栈顶元素是否为空。如果栈溢出,程序终止。栈的数据成员有10个整形数组构成。先后作如下操作:
将10入栈;
将12入栈;
将14入栈;
读出栈顶元素;
退栈;
读出并输出栈顶元素。
展开
 我来答
huifeng00
推荐于2017-10-09 · TA获得超过5235个赞
知道大有可为答主
回答量:808
采纳率:0%
帮助的人:713万
展开全部
#include<iostream>
using namespace std;

class Stack
{
public:
Stack()
{
top=-1;
}
bool push(int n)//压栈
{
if(!isfull())
data[++top]=n;
else
return false;
return true;
}
bool pop()//退栈
{
if(!isempty())
top--;
else
return false;
return true;
}
int gettop()//得到栈顶元素
{
return data[top];
}
bool isempty()//判断是否为空
{
return top==-1?true:false;
}
bool isfull()//判断是否已满
{
return top==9?true:false;
}
private:
int data[10];
int top;
};

int main()
{
Stack s;//建立一个栈
if(!s.push(10))//将10入栈;
{
cout<<"栈溢出"<<endl;
return 0;
}
if(!s.push(12))//将12入栈;
{
cout<<"栈溢出"<<endl;
return 0;
}
if(!s.push(14))//将14入栈;
{
cout<<"栈溢出"<<endl;
return 0;
}
cout<<s.gettop()<<endl;//读出并输出栈顶元素;
s.pop();//退栈
cout<<s.gettop()<<endl;//读出并输出栈顶元素;
}
如上类,这是可以存储10个整型数空间的栈。
帐号已注销
推荐于2017-09-23 · TA获得超过3.1万个赞
知道大有可为答主
回答量:6571
采纳率:86%
帮助的人:922万
展开全部
#include<iostream>
using namespace std;

class Stack
{
public:
Stack()
{
top=-1;
}
bool push(int n)//压栈
{
if(!isfull())
data[++top]=n;
else
return false;
return true;
}
bool pop()//退栈
{
if(!isempty())
top--;
else
return false;
return true;
}
int gettop()//得到栈顶元素
{
return data[top];
}
bool isempty()//判断是否为空
{
return top==-1?true:false;
}
bool isfull()//判断是否已满
{
return top==9?true:false;
}
private:
int data[10];
int top;
};

int main()
{
Stack s;//建立一个栈
if(!s.push(10))//将10入栈;
{
cout<<"栈溢出"<<endl;
return 0;
}
if(!s.push(12))//将12入栈;
{
cout<<"栈溢出"<<endl;
return 0;
}
if(!s.push(14))//将14入栈;
{
cout<<"栈溢出"<<endl;
return 0;
}
cout<<s.gettop()<<endl;//读出并输出栈顶元素;
s.pop();//退栈
cout<<s.gettop()<<endl;//读出并输出栈顶元素;
}
如上类,这是可以存储10个整型数空间的栈。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
owlwisp
2009-12-14 · TA获得超过122个赞
知道答主
回答量:164
采纳率:100%
帮助的人:194万
展开全部
#include <iostream>
using namespace std;

#define STACKSIZE 100
typedef char DataType;

void Error(char* _pchMessage);

typedef class CStack
{
private:
DataType m_Data[STACKSIZE];
int m_nTop;
public:
CStack();
~CStack();
void InitStack();
int StackEmpty();
int StackFull();
void PushStack(DataType _Temp);
DataType PopStack();
DataType StackTop();
void ShowStack();

}SeqStack;

CStack::CStack()
{
for(int i = 0; i < STACKSIZE; ++i)
{
m_Data[i] = 0;
}
m_nTop = -1;
}

CStack::~CStack()
{
}

void CStack::InitStack()
{
//将顺序栈置空
for(int i = 0; i < STACKSIZE; ++i)
{
m_Data[i] = 0;
}
m_nTop = -1;
}

int CStack::StackEmpty()
{
return m_nTop == -1;
}

int CStack::StackFull()
{
return m_nTop == STACKSIZE - 1;
}

void CStack::PushStack(DataType _Temp)
{
if(STACKSIZE - 1 == m_nTop)
{
Error("Stack overflow.");
return ;
}

m_Data[++m_nTop] = _Temp;
}

DataType CStack::PopStack()
{
if( -1 == m_nTop)
{
Error("Stack underflow.");
return -1;
}

return m_Data[m_nTop--];
}

DataType CStack::StackTop()
{
if( -1 == m_nTop)
{
Error("Stack underflow.");
return -1;
}

return m_Data[m_nTop];
}

void CStack::ShowStack()
{
if(-1 == m_nTop)
{
cout << "此栈为空!" << endl;
}
else
{
for(int i = m_nTop; i > -1; --i)
{
cout << m_Data[i] << '\t' << endl;
}
}
}

int main()
{
SeqStack* pStack= new SeqStack;
pStack->InitStack();

if(pStack->StackEmpty())
{
cout << "此栈已空!" << endl;
}

if(pStack->StackFull())
{
cout << "此栈已满!" << endl;
}

pStack->PushStack('a');
pStack->PushStack('b');
pStack->PushStack('c');
pStack->PushStack('d');
pStack->PushStack('e');

cout << "PopStack = " << pStack->PopStack() << endl;
cout << "StackTop = " << pStack->StackTop() << endl;

pStack->ShowStack();

delete pStack;
pStack = NULL;

return 0;
}

void Error(char* _pchMessage)
{
fprintf(stderr, "Error: %s\n", _pchMessage);
cout << _pchMessage << endl;
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
宋浩飞惠君
2020-04-29 · TA获得超过3642个赞
知道大有可为答主
回答量:3090
采纳率:31%
帮助的人:384万
展开全部
#include<iostream>
using
namespace
std;
class
Stack
{
public:
Stack()
{
top=-1;
}
bool
push(int
n)//压栈
{
if(!isfull())
data[++top]=n;
else
return
false;
return
true;
}
bool
pop()//退栈
{
if(!isempty())
top--;
else
return
false;
return
true;
}
int
gettop()//得到栈顶元素
{
return
data[top];
}
bool
isempty()//判断是否为空
{
return
top==-1?true:false;
}
bool
isfull()//判断是否已满
{
return
top==9?true:false;
}
private:
int
data[10];
int
top;
};
int
main()
{
Stack
s;//建立一个栈
if(!s.push(10))//将10入栈;
{
cout<<"栈溢出"<<endl;
return
0;
}
if(!s.push(12))//将12入栈;
{
cout<<"栈溢出"<<endl;
return
0;
}
if(!s.push(14))//将14入栈;
{
cout<<"栈溢出"<<endl;
return
0;
}
cout<<s.gettop()<<endl;//读出并输出栈顶元素;
s.pop();//退栈
cout<<s.gettop()<<endl;//读出并输出栈顶元素;
}
如上类,这是可以存储10个整型数空间的栈。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式