SPL提供了双向链表、堆栈、队列、堆、降序堆、升序堆、优先级队列、定长数组、对象容器

SplQueue 队列类

进出异端,先进先出

在这里插入图片描述
<?php$obj = new SplQueue();//插入一个节点到top位置$obj->enqueue(1);$obj->enqueue(2);$obj->enqueue(3);/**SplQueue Object(    [flags:SplDoublyLinkedList:private] => 4    [dllist:SplDoublyLinkedList:private] => Array        (            [0] => 1            [1] => 2            [2] => 3        ))*/$obj->offsetSet(0,'C');/**SplQueue Object(    [flags:SplDoublyLinkedList:private] => 4    [dllist:SplDoublyLinkedList:private] => Array        (            [0] => 'C'            [1] => 2            [2] => 3        ))*/$obj->rewind();//从队列中返回并删除bottom位置的元素$obj->dequeue();/**'C'SplQueue Object(    [flags:SplDoublyLinkedList:private] => 4    [dllist:SplDoublyLinkedList:private] => Array        (            [0] => 2            [1] => 3        ))*/复制代码

SplStack 堆栈类

单端进出时,后进先出,先进后出

在这里插入图片描述
$obj = new SplStack();/**SplStack Object(    [flags:SplDoublyLinkedList:private] => 6    [dllist:SplDoublyLinkedList:private] => Array        (        ))*///向堆栈放入一个节点到top位置$obj->push(1);$obj->push(2);$obj->push(3);/**SplStack Object(    [flags:SplDoublyLinkedList:private] => 6    [dllist:SplDoublyLinkedList:private] => Array        (            [0] => 1            [1] => 2            [2] => 3        ))*///堆栈的offset = 0 是Top所在的位置,offset = 1 是top节点靠近bottom位置的相邻节点$obj->offsetSet(0,'C');/**SplStack Object(    [flags:SplDoublyLinkedList:private] => 6    [dllist:SplDoublyLinkedList:private] => Array        (            [0] => 1            [1] => 2            [2] => 'C'        ))*/$obj->offsetSet(1,'B');/**SplStack Object(    [flags:SplDoublyLinkedList:private] => 6    [dllist:SplDoublyLinkedList:private] => Array        (            [0] => 1            [1] => 'B'            [2] => 'C'        ))*///堆栈的rewind使指针指向top节点,而双向链表的rewind指向bottom节点$obj->rewind();//堆栈的next是使指针向bottom方向相邻的节点移动一位,而链表是向top方向移动$obj->next();//遍历堆栈$obj->rewind();while($obj->valid()){    echo $obj->key().'=>'.$obj->current();    $obj->next();}/**2=>'C'1=>'B'0=>1*///从堆栈中取出top位置的节点并删除$obj->pop();复制代码

SplDoublyLinkedList 双向链表类

在这里插入图片描述
$obj = new SplDoublyLinkedList();//SplDoublyLinkedList Object ( [flags:SplDoublyLinkedList:private] => 0 [dllist:SplDoublyLinkedList:private] => Array ( ) )//把新的节点数据添加到链表的顶部Top$obj->push(1);$obj->push(2);$obj->push(3);//把新的节点数据添加到链表底部bottom$obj->unshift(4);/**SplDoublyLinkedList Object(    [flags:SplDoublyLinkedList:private] => 0    [dllist:SplDoublyLinkedList:private] => Array        (            [0] => 4            [1] => 1            [2] => 2            [3] => 3        ))*///在没有调用rewind()方法之前输出为nullecho 'current'.$obj->current();//输出: null//把指针指向bottom节点$obj->rewind();//获取当前指针指向的节点$obj->current();//输出: 4//将执行挪到下一个$obj->next();$obj->current();//输出: 1$obj->prev();$obj->current();//输出: 4//越界了$obj->next();$obj->next();$obj->next();$obj->next();$obj->current();//输出: null//判断当前节点是否有效$obj->valid()//输出: false$obj->prev();$obj->valid()//输出: true$obj->shift();//把top节点从链表中删除并返回$obj->pop();//输出 3//把bottom节点从链表中删除并返回$obj->shift();//输出 4//返回top节点$obj->top();//返回bottom节点$obj->bottom();复制代码

感谢您的阅读,如果对您有帮助,欢迎关注"CRMEB"。码云上有我们开源的商城项目,知识付费项目,均是基于PHP+vue开发,学习研究欢迎使用,关注我们保持联系!

想了解更多编程学习,敬请关注php培训栏目!

更多相关文章

  1. php+nodeJs+thrift协议,实现zookeeper节点数据自动发现
  2. jQuery的DOM操作实例(3)——创建节点&&编写一个弹窗
  3. jQuery编程基础精华02(属性、表单过滤器,元素的each,表单选择器,子元
  4. 如何在java脚本中获取节点内部文本?
  5. Study JQuery《zTree自动点击第一个节点》
  6. 如何使用ajax GET或POST方法将数据传递到amazon lambda节点。js
  7. jQuery.zTree 点击节点展开折叠子节点
  8. easyui-tree根据叶子节点获取父节点值(N层)
  9. PHP递归函数删除所有子节点导致stackoverflow

随机推荐

  1. Fedora 15下使用android ndk 编译ffmepg0
  2. Android添加背景音乐的方法
  3. Android自定义标题栏
  4. android 开发 时间选择器TimePicker的使
  5. Android studio 串口通信(动态获取串口)
  6. Android 使用CountDownTimer实现倒计时
  7. Android基于Handler实现倒计时
  8. android安装后控件拖不动问题解答
  9. Android 中可重写的一些样式
  10. android Intent的一些用法