美文网首页
数据结构 栈和队列

数据结构 栈和队列

作者: 旋律sama | 来源:发表于2019-04-04 12:53 被阅读0次

数据结构 栈和队列

顺序栈

top = -1

链栈

  • 初始化
  • 判断队空
  • 入队: 头插法
  • 出队: 单链表删除

队列

顺序队

front, rear
%MAXSIZE

链队

若有头节点 则队头在头节点后,队尾在链表尾部

基本操作:

  • 初始化
  • 判断队空
  • 入队: lqu->rear->next = p; lqu->rear = p;
  • 出队: p = lqu->front; lqu->front = p->next; x = p->data; free(p);

其他

  1. 共享栈
  2. 双端队列
  • 输入受限:一端皆可,一端只输出
  • 输出受限: 一端皆可,一端只输入

应用:

1. 表达式转换

中缀 -> 后缀

  • 左 -> 右
  • 数字写,空栈入,大于入,左括号入,栈顶左括号入,右括号出 直到左括号,小于等于出 左括号入
  • image

中缀 -> 前缀

  • 右 -> 左
  • 数字写,空栈入,大于等于入,右括号入,栈顶右括号入,左括号出 直到右括号,小于出 右括号入
  • image
  • 图标题有误!

后缀 -> 前缀

  • 数入 数入 组合后符号提前入

2. 表达式求值

注意顺序, 建立两个栈

中缀

  • 数字入 符号大于入 左括号入 小于等于出2数1号 栈空依次出

后缀

  • (左 -> 右)
  • 数字入栈
  • 遇到符号出栈 2个数,并将计算结果入栈
  • 重复

前缀

  • (右 -> 左)
  • 数字入栈
  • 遇到符号出栈 2个数,并将计算结果入栈
  • 重复

3. 用栈模拟队列

限制:只能全入再全出,不能中断
队满:s1满且s2不空
队空:s1,s2空

入队规则:

  • 若s1未满,直接入栈s1
  • 若s1满,s2为空,将s1全部倒入s2,再入栈s1

出队规则:

  • 若s2不空,直接出栈
  • 若s2空,s1倒入s2后,再出栈

正常配置

正常配置:入队-先移动指针再入队元素,出队-先移动指针再取元素

  • 队满: front = (rear+1) % maxSize
  • 元素个数: ( rear - front + maxSize ) % maxSize

非正常配置

非正常配置: 入队-先入队元素再移动指针,出队-先移动指针再取元素 etc... !还有其他

  • 队满: front = (rear+1) % maxSize
  • 元素个数: ( rear - front + maxSize ) % maxSize

双端队列

在某一端进行输入或输出的限制

  • 毫无限制
  • 输入限制
  • 输出限制
    不可能的序列为:全排列-卡特兰数

相关文章

  • Algorithm小白入门 -- 队列和栈

    队列和栈队列实现栈、栈实现队列单调栈单调队列运用栈去重 1. 队列实现栈、栈实现队列 队列是一种先进先出的数据结构...

  • 栈和队列—什么是栈

    栈和队列是两种重要的数据结构 从数据结构角度看,栈和队列也是线性表,其特殊性在于栈和队列的基本操作是线性表操作的子...

  • 栈和队列—什么是队列

    栈和队列是两种重要的数据结构 从数据结构角度看,栈和队列也是线性表,其特殊性在于栈和队列的基本操作是线性表操作的子...

  • 队列和栈的应用

    队列和栈的使用 标签(空格分隔): algorithm 队列和栈的应用 1.队列的应用 队列是一种常见的数据结构,...

  • 泡杯茶,我们坐下聊聊javascript事件环

    栈和队列 在计算机内存中存取数据,基本的数据结构分为栈和队列。 栈(Stack)是一种后进先出的数据结构,注意,有...

  • 算法导论 基本数据结构

    MIT公开课没有讲到的内容,介绍几种基本数据结构- 栈和队列- 链表- 二叉树 栈和队列 栈和队列都是动态集合,元...

  • 栈、队列和链表

    基本数据结构 栈和队列 栈和队列都是动态集合。栈实现的是一种后进先出策略。队列是一种先进先出策略。 栈 栈上的in...

  • 数据结构:栈和队列

    栈和队列 栈和队列是软件设计中常用的两种数据结构,逻辑结构和线性表相同。 特点: 栈: "先进后出"队列:"先进先...

  • 数据结构 栈和队列

    数据结构 栈和队列 栈 顺序栈 top = -1 链栈 初始化 判断队空 入队: 头插法 出队: 单链表删除 队列...

  • 第四章栈与队列

    知识大纲 栈和队列的数据结构 相同点 栈和队列都是对删除和插入做了限制的线性表 栈和队列的都是建立在线性表的...

网友评论

      本文标题:数据结构 栈和队列

      本文链接:https://www.haomeiwen.com/subject/rfufiqtx.html