码迷,mamicode.com
首页 > 其他好文 > 详细

数据结构(2) -- 堆栈

时间:2015-04-05 21:45:16      阅读:117      评论:0      收藏:0      [点我收藏+]

标签:

1、顺序存储


//栈的顺序存储实现
//Stack.h
#ifndef STACK_H_
#define STACK_H_
#define ElementType int 
#define MaxSize 100
typedef struct _Node
{
    ElementType data[MaxSize];
    int top;
}Node;
class Stack
{
private:
    Node data;
public:
    Stack();
    ~Stack();
    int IsFull();
    void Push(ElementType item);
    int IsEmpty();
    ElementType Pop();
};
#endif

//Stack.cpp
#include "Stack.h"
#include <iostream>

Stack::Stack()
{
    data.top = -1;
}
Stack::~Stack()
{
}
int Stack::IsFull()
{
    if (data.top == (MaxSize - 1))
        return 1;
    else
        return 0;
}
void Stack::Push(ElementType item)
{
    if (IsFull() == 1)
    {
        std::cout << "栈溢出" << std::endl;
        return;
    }
    data.data[++(data.top)] = item;
}

int Stack::IsEmpty()
{
    if (data.top == -1)
        return 1;
    else
        return 0;
}

ElementType Stack::Pop()
{
    if (IsEmpty())
        std::cout << "栈已空" << std::endl;
    return data.data[(data.top)--];
}

 

 

 

2、链式存储

//栈的链式存储实现
//PStack.h
#ifndef PSTACK_H_
#define PSTACK_H_
#define ElementType int 
#define MaxSize 100
typedef struct _PNode
{
    ElementType data;
    _PNode* next;
}PNode;

class PStack
{
private:
    PNode *top;
public:
    PStack();
    ~PStack();
    int IsFull();
    void Push(ElementType item);
    int IsEmpty();
    ElementType Pop();
};
#endif


//PStack.cpp
#include "PStack.h"
#include <iostream>

PStack::PStack()
{
    top = new PNode();
    top->next = NULL;
}
PStack::~PStack()
{
    delete top;
}

void PStack::Push(ElementType item)
{    
    PNode* s = new PNode();
    s->data = item;
    s->next = top;
    top = s;
}

int PStack::IsEmpty()
{
    if (top == NULL)
        return 1;
    else
        return 0;
}

ElementType PStack::Pop()
{
    if (IsEmpty())
        std::cout << "栈已空" << std::endl;
    PNode *s;
    s = top;
    ElementType e = s->data;
    top = top->next;
    delete s;
    return e;
}

 

3、测试样例

#include <iostream>
#include "PStack.h"
using namespace std;

int main()
{
    PStack st;
    st.Push(5);
    st.Push(6);
    st.Push(2);
    int a = st.Pop();
    int b = st.Pop();
    cout << "a , b" << a << " " << b << endl;
    st.Push(b / a);
    a = st.Pop();
    b = st.Pop();
    cout << "a , b" << a << " " << b << endl;
    st.Push(b + a);
    st.Push(3);
    st.Push(4);
    a = st.Pop();
    b = st.Pop();
    cout << "a , b" << a << " " << b << endl;
    st.Push(b * a);
    a = st.Pop();
    b = st.Pop();
    st.Push(b - a);
    cout << "a , b" << a << " " << b << endl;
    cout << "根据后缀表达是计算5+6/2-3*4的值为:" << st.Pop() << endl;

    system("pause");
    return 0;
}

 

数据结构(2) -- 堆栈

标签:

原文地址:http://www.cnblogs.com/yongssu/p/4394776.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!