线性表之顺序栈

栈是限定仅在表尾(栈顶)进行插入删除操作的线性表,FILO:先进后出

一、顺序栈的头文件:SeqStack.h

 //顺序栈头文件
#include<iostream>
using namespace std;
//设置顺序栈的大小
const int StackSize = ;
template<class DataType>
//定义顺序栈的模板类型
class SeqStack{
public:
  //无参构造器,初始化栈顶指针
  SeqStack(){ top = -; }
  //析构函数为空
  ~SeqStack(){}
  //入栈操作,将元素入栈
  void Push(DataType x);
  //出栈操作,将栈顶元素弹出栈
  DataType Pop();
  //取出栈顶元素,不删除栈顶元素(即取出的元素还在栈内)
  DataType GetTop();
  //判断栈是否为空
  int IsEmpty();
private:
  //存放站元素的指针
  DataType data[StackSize];
  //栈顶指针:栈顶元素在数组中的下标
  int top;
}; //实现顺序栈入栈操作
template<class DataType>
void SeqStack<DataType>::Push(DataType x)
{
  //判断当前顺序栈是否已是满栈
  if (top == StackSize - )
  {
    throw "栈已满";
  }
  else
  {
    //如果当前顺序栈不满,则栈顶值栈向上移动一个单元
    top++;
    //给新的栈顶元素赋值
    data[top] = x;
  }
} //实现顺序栈出栈,弹出栈顶元素
template<class DataType>
DataType SeqStack<DataType>::Pop()
{
  //先判断是否是空栈
  if (top == -)
  {
    throw "栈是空栈";
  }
  else
  {
    //若不是空栈,则取出栈顶元素,并删除栈顶元素
    DataType x = data[top];
    //栈顶指针向下移动一个单元素
    top--;
    //返回栈顶元素的值
    return x;
  }
} //实现取出栈顶元素,但不删除取出的元素
template<class DataType>
DataType SeqStack<DataType>::GetTop()
{
  //先判断是否是空栈
  if (top == -)
  {
    throw "栈是空栈";
  }
  else
  {
    //若不是空栈,则取出栈顶元素的值,但不删除栈顶元素
    DataType x = data[top];
    //返回栈顶元素的值
    return x;
  }
} //实现判断顺序栈是否是空栈:栈空返回 1,否则返回 0
template<class DataType>
int SeqStack<DataType>::IsEmpty()
{   if (top == -)
  {
    return ;
  }
  else
  {
    return ;
  }
}

二、测试顺序栈的源文件:TestSeqStack.cpp

 //测试顺序栈
#include<iostream>
//引入顺序栈头文件
#include"SeqStack.h"
using namespace std;
int main()
{
  //创建一个顺序栈
  SeqStack<int> seqStack = SeqStack<int>();
  //判断是否是空栈
  cout << "此时栈是否是空栈:" << seqStack.IsEmpty() << endl;
  //入栈
  seqStack.Push();
  cout << "1 入栈了" << endl;
  //判断是否是空栈
  cout << "此时栈是否是空栈:" << seqStack.IsEmpty() << endl;
  //取出栈顶元素
  cout << "栈顶元素是:" << seqStack.GetTop() << endl;
  //出栈
  seqStack.Push();
  cout << "3 入栈了" << endl;
  //取出栈顶元素
  cout << "栈顶元素是:" << seqStack.GetTop() << endl;
  //出栈
  seqStack.Push();
  cout << "7 入栈了" << endl;
  //取出栈顶元素
  cout << "栈顶元素是:" << seqStack.GetTop() << endl;
  //出栈
  seqStack.Push();
  cout << "5 入栈了" << endl;
  //取出栈顶元素
  cout << "栈顶元素是:" << seqStack.GetTop() << endl;
  //出栈
  cout << "栈顶元素" << seqStack.Pop() << "出栈了" << endl;
  //取出栈顶元素
  cout << "栈顶元素是:" << seqStack.GetTop() << endl;
  //出栈
  return ;
}

 三、运行示例结果:

线性表之顺序栈C++实现的更多相关文章

  1. 数据结构算法C语言实现(一)---2.2线性表的顺序表示和实现

    注意: 虽然是用C语言实现,但是考虑到使用了一个C++的特性----引用以简化代码,所以所有的代码均以cpp作为后缀,用g++编译(以后不做说明). g++版本: 一.简述 本节主要讲述线性表的顺序实 ...

  2. C#线性表之顺序表

    线性表是最简单.最基本.最常用的数据结构.线性表是线性结构的抽象(Abstract), 线性结构的特点是结构中的数据元素之间存在一对一的线性关系. 这种一对一的关系指的是数据元素之间的位置关系,即: ...

  3. D_S 线性表的顺序表示和实现

    线性表的顺序表示又称为顺序存储结构或顺序映像 顺序存储定义:把逻辑上相邻的数据元素存储在物理上相邻的存储单元中的存储结构,简言之,逻辑上相邻,物理上也相邻 顺序存储方法:用一组地址连续的存储单元依次存 ...

  4. javascript实现数据结构:线性表--简单示例及线性表的顺序表示和实现

    线性表(linear list)是最常用且最简单的一种数据结构.一个线性表是n个数据元素的有限序列.在稍复杂的线性表中,一个数据元素可以由若干个数据项(item)组成. 其中: 数据元素的个数n定义为 ...

  5. c/c++ 线性表之顺序表

    线性表之顺序表 存储在连续的内存空间,和数组一样. 下面的代码,最开始定义了一个能存8个元素的顺序表,当超过8个元素的时候,会再追加开辟空间(函数:reInit). 实现了以下功能: 函数 功能描述 ...

  6. 已知长度为n的线性表采用顺序结构,写一算法删除该线性表中所有值为item的元素

    /** * @author:(LiberHome) * @date:Created in 2019/2/27 23:34 * @description: * @version:$ */ /*已知长度为 ...

  7. 线性表之顺序表C++实现

    线性表之顺序表 一.头文件:SeqList.h //顺序线性表的头文件 #include<iostream> ; //定义顺序表SeqList的模板类 template<class ...

  8. 线性表中顺序表的的理解和实现(java)

    线性表的顺序表示指的是用一组地址连续的存储单元以此存储线性表的数据元素,这种表示也称作线性表的顺序存储结构或顺序映像.通常,称这种存储结构的线性表为顺序表.特点是:逻辑上相邻的数据元素,其物理次序上也 ...

  9. [C++]数据结构:线性表之顺序表

    1 顺序表 ADT + Status InitList(SeqList &L) 初始化顺序表 + void printList(SeqList L) 遍历顺序表 + int ListLengt ...

随机推荐

  1. 凸包入门(Graham扫描法)(A - Wall POJ - 1113)

    题目链接:https://cn.vjudge.net/contest/276359#problem/A 题目大意:有一个国王,要在自己的城堡周围建立围墙,要求围墙能把城堡全部围起来,并且围墙距离城堡的 ...

  2. 20165230 2017-2018-2 《Java程序设计》第9周学习总结

    20165230 2017-2018-2 <Java程序设计>第9周学习总结 教材学习内容总结 第十二章 java网络编程 学习了用于网络编程的类,了解URL.Socket.InetAdd ...

  3. 关于maven环境下使用pom.xml引入包名.lastUpdate包的解决办法

    今天在导入POI-OOXML的时候总是缺失xmlbeans包,而且刷新pom文件总是生成一个lastupdate文件,大小为1KB,终于找到解决办法. 1.首先删除想要的jar包所在文件夹内的所有 . ...

  4. 聊天室(上篇)GatewayWorker 基础

    前言 本文的目的是基于 GatewayWorker 官方手册,梳理一次 GatewayWorker,并在实践中与 MVC 框架整合的思路(附最终的项目源码).如果你已经理解了整合这一块儿的知识,那么就 ...

  5. O_NONBLOCK与O_NDELAY有何不同?

    O_NONBLOCK和O_NDELAY所产生的结果都是使I/O变成非搁置模式(non-blocking),在读取不到数据或是写入缓冲区已满会马上return,而不会搁置程序动作,直到有数据或写入完成. ...

  6. 好用的工具---screen命令

    问 题场景:要在服务器上配置环境,但是我的电脑无法直接连到服务器上,通常要经过好几次ssh跳转.配环境需要设置好几个用户,这自然需要同时打开好几个连 接服务器的终端窗口,每个连接到服务器的终端窗口都要 ...

  7. php中heredoc的使用方法

    Heredoc技术,在正规的PHP文档中和技术书籍中一般没有详细讲述,只是提到了这是一种Perl风格的字符串输出技术.但是现在的一些论坛程序,和部分文章系统,都巧妙的使用heredoc技术,来部分的实 ...

  8. java基础17 模板模式

    1.模版模式 解决某类事物的步骤有些是固定的,有些会发生改变的,那么这个时候我们可以为这一类事物提供一个模版代码,从而提高效率. 2.模版模式的步骤 1.先写出解决该类事物的其中一种解决方案;     ...

  9. 使用html+css+js实现日历与定时器,看看今天的日期和今天剩余的时间。

    使用html+css+js实现日历与定时器,看看今天的日期和今天剩余的时间. 效果图: 哎,今天就又这么过去了,过的可真快 . 代码如下,复制即可使用: <!DOCTYPE html> & ...

  10. vue-cli脚手架安装

    -1.安装淘宝镜像 $ alias cnpm="npm --registry=https://registry.npm.taobao.org \ --cache=$HOME/.npm/.ca ...