美文网首页
栈和队列

栈和队列

作者: 沧州宁少 | 来源:发表于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

    相关文章

      网友评论

          本文标题:栈和队列

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