当前位置:Gxlcms > PHP教程 > PHPSPL标准库之数据结构栈(SplStack)介绍_PHP

PHPSPL标准库之数据结构栈(SplStack)介绍_PHP

时间:2021-07-01 10:21:17 帮助过:3人阅读

栈(Stack)是一种特殊的线性表,因为它只能在线性表的一端进行插入或删除元素(即进栈和出栈)

SplStack就是继承双链表(SplDoublyLinkedList)实现栈。

类摘要如下:

简单使用如下:

  1. //把栈想象成一个颠倒的数组
  2. $stack = new SplStack();
  3. /**
  4. * 可见栈和双链表的区别就是IteratorMode改变了而已,栈的IteratorMode只能为:
  5. * (1)SplDoublyLinkedList::IT_MODE_LIFO | SplDoublyLinkedList::IT_MODE_KEEP (默认值,迭代后数据保存)
  6. * (2)SplDoublyLinkedList::IT_MODE_LIFO | SplDoublyLinkedList::IT_MODE_DELETE (迭代后数据删除)
  7. */
  8. $stack->setIteratorMode(SplDoublyLinkedList::IT_MODE_LIFO | SplDoublyLinkedList::IT_MODE_DELETE);
  9. $stack->push('a');
  10. $stack->push('b');
  11. $stack->push('c');
  12. $stack->pop(); //出栈
  13. $stack->offsetSet(0, 'first');//index 为0的是最后一个元素
  14. foreach($stack as $item) {
  15. echo $item . PHP_EOL; // first a
  16. }
  17. print_R($stack); //测试IteratorMode

人气教程排行