(转载)http://myswirl.blog.163.com/blog/static/51318642200882310239324/

SqStack.h
****************************************
#include <iostream>
using std::cout;
using std::endl;

template <class T>
class SqStack{
    public:
        SqStack(int init=50, int incr=10);
        bool StackEmpty() const;//判断栈是否为空
        T *GetTop() const;//得到栈顶指针
        void StackTraverse() const;
        
        bool Push(T &s);//入栈
        bool Pop(T &p);//出栈
        
        ~SqStack();
    private:
        int size; //允许的最大存储空间以元素为单位
        int increaseSize;//递增大小
        T *base; //存储空间基址
        int top; //栈顶指针,栈元素个数 
};
//构造函数
template <class T>
SqStack<T>::SqStack(int init, int incr){
    size = init; //初始大小
    base = new T[size];
    if(!base)exit(1);//存储分配失败
    increaseSize = incr; //顺序表递增大小
    top = 0;   //空栈中元素个数为0
}

template <class T>
bool SqStack<T>::StackEmpty() const{
    return top == 0;
}
//返回栈顶指针
template <class T>
T *SqStack<T>::GetTop() const{
    if( top == 0 )return NULL;//空栈
    return base+top-1;
}
template <class T>
void SqStack<T>::StackTraverse() const{
    if( top == 0 ){
        cout<<"遍历为空栈"<<endl;
    }else{
        //栈底到栈顶输出
        cout<<"栈底到栈顶: ";
        for(int i=0; i<top; i++){
            cout << *(base+i) << " ";
        }
        cout<<endl;
    }
}
//入栈
template <class T>
bool SqStack<T>::Push(T &s){
    if(top == size)return false; //栈已满,无法进行插入
    *(base + top) = s;//插入新的元素
    ++top;
    return true;
}
//出栈,返回删除元素的指针
template <class T>
bool SqStack<T>::Pop(T &p){
    if( top == 0 )return false;//空栈
    p = *(base+top-1);
    --top;
    return true;
}
//析构函数
template <class T>
SqStack<T>::~SqStack(){
    cout << "调用析构函数" << endl;
    delete base;
    base = NULL;
}
*****************************************

main.cc
**********************************************

#include "SqStack.h"

int main()
{
    SqStack<int> *s = new SqStack<int>;
    
    int a = 0;
    int b = 1;
    int c = 2;
    
    if(s->Push(a)){
        cout << "入栈成功!a"<<endl;
    }
    if(s->Push(b)){
        cout << "入栈成功!b"<<endl;
    }
    
    if( s->GetTop() != NULL ){
        cout << "栈顶元素: " << *(s->GetTop()) << endl;    
    }else{
        cout << "空栈了" <<endl;
    }
    
    s->StackTraverse();
    
    int p;
    if( s->Pop(p)){
        cout << "出栈成功!" << p << endl;
    }else{
        cout << "空栈" << endl;
    }
    
    if( s->GetTop() != NULL ){
        cout << "栈顶元素: " << *(s->GetTop()) << endl;    
    }else{
        cout << "栈顶元素:NULL" <<endl;
    }
    s->StackTraverse();
    return 0;
}

**********************************************

(转载)顺序栈c++实现的更多相关文章

  1. 数据结构:C_顺序栈的实现

    数据结构顺序栈的实现(C语言版) 1.写在前面 栈是一种遵循元素先进(Push)后出(Pop)规则的线性表,它的实现可以用数组或者链表. ..... 2.代码分解 2.1对栈的结构定义: typede ...

  2. D_S 顺序栈的基本操作

    //  main.cpp #include <iostream> using namespace std; #include "Status.h" typedef in ...

  3. 数据结构Java实现05----栈:顺序栈和链式堆栈

    一.堆栈的基本概念: 堆栈(也简称作栈)是一种特殊的线性表,堆栈的数据元素以及数据元素间的逻辑关系和线性表完全相同,其差别是线性表允许在任意位置进行插入和删除操作,而堆栈只允许在固定一端进行插入和删除 ...

  4. 01顺序栈_Stack---(栈与队列)

    #include "stdio.h" #include "stdlib.h" #include "io.h" #include " ...

  5. 把十进制整数转换为r(r=2)进制输出(顺序栈实现)

    上周的第二个作业补上~~ 上周的要求: 1.给出顺序栈的存储结构定义. 2.完成顺序栈的基本操作函数. 1)      初始化顺序栈 2)      实现入栈和出栈操作 3)      实现取栈顶元素 ...

  6. 数据结构之顺序栈SqStack

    顺序栈SqStack 基本操作 Status InitStack()//构造一个空栈S Status DestroyStack()//销毁栈S,S不再存在 Status ClearStack()//把 ...

  7. 顺序栈之C++实现

    顺序栈就是用顺序表(数组)实现的栈.其组织形式如下图所示: 下面介绍下我用C++实现的顺序栈,在VC6下调试通过.不足之处还请指正. 1.文件组织 2.ss.h栈类的声明及宏的定义 #ifndef _ ...

  8. 顺序栈和链式栈(C++实现)

    顺序栈,是一种基于数组的存储表示. 实现类代码如下: template<class T> class SeqStack{ T *element; int top; int maxSize; ...

  9. salesforce零基础学习(七十六)顺序栈的实现以及应用

    数据结构中,针对线性表包含两种结构,一种是顺序线性表,一种是链表.顺序线性表适用于查询,时间复杂度为O(1),增删的时间复杂度为O(n).链表适用于增删,时间复杂度为O(1),查询的时间复杂度为O(n ...

  10. 【小白成长撸】--顺序栈(C语言版)

    // 顺序栈.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h"//test1.0--栈表仅限Int类型 #include <stdio. ...

随机推荐

  1. /Users/XX/Library/Developer/Xcode/DerivedData/XX.app/xxsdk.bundle Directory not empty

    今天在升级xcode后真机调试偶然发现这个问题,查了一些资料发现还是不能完全解决 解决方法:参考的(http://blog.csdn.net/alincexiaohao/article/details ...

  2. ORACLE 关连更新 update select

    总结:  关键的地方是where 语句的加入. 在11G中, 如果不加11G , 或造成除匹配的行数更新为相应的值之后, 其余的会变成负数. 所以, 测试的办法就是:  先查看需要更新的数量即连接的数 ...

  3. javaScript笔记1

    一.通过 id 访问HTML元素,可以使用 document.getElementById(id) 方法. 例子: <body> <button id="mybtn&quo ...

  4. 【笔记】mongodb启动不了:child process failed, exited with error number 100

    今天在启动mongodb的时候,发现起不来,报错:child process failed, exited with error number 100然后先去/var/log/mongo/mongod ...

  5. boa服务器问题日志

    1. 某一次在登录boa服务器的时候,不知哪里的问题,无法登录「192.168.1.0-192.168.3.255」网段的设备,但是公司IP网段的机器都可以用.最终发现,问题出现在自己的PC添加了浏览 ...

  6. Codevs 3287 货车运输 2013年NOIP全国联赛提高组(带权LCA+并查集+最大生成树)

    3287 货车运输 2013年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 传送门 题目描述 Description A 国有 n 座 ...

  7. HDU_2156 分数矩阵

    Problem Description             我们定义如下矩阵:            1/1 1/2 1/3            1/2 1/1 1/2            1 ...

  8. 禁止 apache 开机启动

    sudo update-rc.d apache2 disable http://askubuntu.com/questions/19320/what-is-the-recommended-way-to ...

  9. 结构型模式(Structural patterns)->外观模式(Facade Pattern)

    动机(Motivate): 在软件开发系统中,客户程序经常会与复杂系统的内部子系统之间产生耦合,而导致客户程序随着子系统的变化而变化.那么如何简化客户程序与子系统之间的交互接口?如何将复杂系统的内部子 ...

  10. 破解https和https原理

    http://blog.csdn.net/cch5487614/article/details/6364711 http://www.jb51.net/network/68135.html