栈部分整理(二)

链式栈(链式存储)

定义

内容(栈中元素data+栈顶指针)

  • 栈是线性表的特例,线性表的存储结构还有链式存储,所以也可以用链表的方式实现栈。栈的链式存储叫做链栈。
  • 每个单链表都有头指针,对于链栈也是必须的,将头指针作为栈顶指针

注意

  • 链栈一般不存在栈满的情况
  • 链栈一般不存在栈满的情况

栈部分整理(二)

操作

链栈压栈(元素进栈)

思想
  • 1、申请新的栈结点(Stack_Node)p,若申请失败,返回false
  • 2、将值赋给p
  • 3、p—>next=top—>next
  • 4、top—>next=p
    栈部分整理(二)

链栈弹栈(元素出栈)

思想
  • 1、新声明一个栈结点用来记录删除的结点
  • 2、判断是否栈空top—>next=NULL
  • 3、取出栈顶元素赋给p,p=top—>next,e=p—>data
  • 4、修改栈顶指针,top—>next=p—>next,释放p结点
    栈部分整理(二)