美文网首页
栈和队列

栈和队列

作者: 沧州宁少 | 来源:发表于2017-07-23 15:18 被阅读0次

栈和队列

栈是一种先进后出 只能在表尾进行插入和删除的线性表,我们把允许插入和删除的一端叫做栈顶,另一端叫做栈底。不含任何数据元素的叫做空栈。LIFO结构。

栈不一定是顺序存储结构的线性表,栈也可能是链式存储结构的线性表,简称链栈。

1.2.3 入栈顺序,出栈的顺序一定是3,2,1吗? 很显然不是。因为栈只对出栈和入栈的位置就行了约束,即表尾(栈顶)但是并没有对出栈和入栈的时间进行约束。

栈由于是一种特殊的线性表,它也分为顺序存储和链式存储。

  • 顺序栈。类比数组,数组的尾巴模拟栈顶
  • 链栈。 去掉头结点,虽然头结点不是必须的,但是常规都有,头指针和栈顶指针合二为一。这样的话,原来判断空栈的条件是头指针的执行为NULL。变为栈顶指针top = NULL
 ` 入栈  s = (Node*)malloc(sizeof(Node)); s->next = S->top; S->top = s;  S->count ++; return OK`

 ` 出栈  p = S->top; S->top = p->next ;  free(q);S->Count -- ; `

共享栈

两个相同类型的栈,通过横过来,让一个的栈底变为数组下标的0处,另外一个变为数组下标的末端即n-1处。这样如果两个栈增加元素,就是两端点向中心延伸。    

栈的一个主要应用:递归

菲波那切数列

func Fbi(number:Int)->Int{ if number<2{ return number == 0 ? 0 : 1 return Fbi(number- 1) + Fbi(number -2 ) } }

逆波兰表示

后缀表达式的用法,遇到数字就入栈,遇到运算符就出栈,进行运算。

队列

队列是一种特殊的线性表。

链队列插入元素s

s->next = NULL

Q->rear->next = s

Q->rear = s

相关文章

  • 数据结构——栈和队列

    用数组实现栈和队列 用栈实现队列 用队列实现栈 栈和队列的经典算法题最小间距栈宠物收养所 数组实现栈和队列 用数组...

  • 栈和队列

    用栈定义队列(出入栈) 用队列定义栈(数据队列和辅助队列)

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

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

  • 栈和队列

    栈和队列 本质上是稍加限制的线性表 栈和队列定义 栈顺序栈定义 链栈结点定义 队列顺序队列 链队列链队类型定义 链...

  • Python实现栈和队列以及使用list模拟栈和队列

    Python实现栈和队列 Python使用list模拟栈和队列

  • 算法-栈和队列算法总结

    栈和队列算法总结 1 模拟 1.1 使用栈实现队列 1.2 使用队列实现栈 2 栈的应用 2.1 栈操作 2.2 ...

  • 算法分析 [BFS、Greedy贪心] 2019-02-18

    队列 和 栈 232. 用栈实现队列 Implement Queue using Stacks双栈,出队列时,将i...

  • 实 验 四 栈和队列

    一、实验目的与要求:## 1、理解栈和队列抽象数据类型。 2、掌握栈和队列的存储结构和操作实现。 3、理解栈和队列...

  • 栈、队列和链表

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

  • 算法导论 基本数据结构

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

网友评论

      本文标题:栈和队列

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