栈和队列

栈和队列

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

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 栈 栈的英文单词是Stack,它代表一种特殊的线性表,这种线性表只能在固定一端(通常认为是线性表的尾端)进行插入,...
    Jack921阅读 1,552评论 0 5
  • 1、栈 栈是一种先进先出的数据结构。栈顶进栈,栈顶出栈。 数据结构 栈的初始化 进栈 出栈 栈的最小值 2、队列 ...
    xiaoyanhan阅读 227评论 0 0
  • 栈和队列是两种应用非常广泛的数据结构,它们都来自线性表数据结构,都是“操作受限”的线性表。 栈 栈(Stack):...
    karlsu阅读 689评论 0 1
  • 小闹钟的钟阅读 259评论 0 1
  • 现实生活中,两性并不像某些书上所说的,单靠真诚和付出就会一起走进爱的花园。两性既不是单靠精神交流而相亲,也不能仅靠...
    蓝矿阅读 648评论 2 2