PHP 双链表(SplDoublyLinkedList)简介和使用实例


Posted in PHP onMay 12, 2015

双链表是一种重要的线性存储结构,对于双链表中的每个节点,不仅仅存储自己的信息,还要保存前驱和后继节点的地址。

PHP 双链表(SplDoublyLinkedList)简介和使用实例

PHP SPL中的SplDoublyLinkedList类提供了对双链表的操作。
SplDoublyLinkedList类摘要如下:

SplDoublyLinkedList implements Iterator  , ArrayAccess  , Countable  {
 
  public __construct ( void )
  public void add ( mixed $index , mixed $newval )
  //双链表的头部节点
  public mixed top ( void )
  //双链表的尾部节点
  public mixed bottom ( void )
  //双联表元素的个数
  public int count ( void )
  //检测双链表是否为空
  public bool isEmpty ( void )
 
 
  //当前节点索引
  public mixed key ( void )
  //移到上条记录
  public void prev ( void )
  //移到下条记录
  public void next ( void )
  //当前记录
  public mixed current ( void )
  //将指针指向迭代开始处
  public void rewind ( void )
  //检查双链表是否还有节点
  public bool valid ( void )
 
  //指定index处节点是否存在
  public bool offsetExists ( mixed $index )
  //获取指定index处节点值
  public mixed offsetGet ( mixed $index )
  //设置指定index处值
  public void offsetSet ( mixed $index , mixed $newval )
  //删除指定index处节点
  public void offsetUnset ( mixed $index )
 
  //从双链表的尾部弹出元素
  public mixed pop ( void )
  //添加元素到双链表的尾部
  public void push ( mixed $value )
 
  //序列化存储
  public string serialize ( void )
  //反序列化
  public void unserialize ( string $serialized )
 
  //设置迭代模式
  public void setIteratorMode ( int $mode )
  //获取迭代模式SplDoublyLinkedList::IT_MODE_LIFO (Stack style) SplDoublyLinkedList::IT_MODE_FIFO (Queue style)
  public int getIteratorMode ( void )
 
  //双链表的头部移除元素
  public mixed shift ( void )
  //双链表的头部添加元素
  public void unshift ( mixed $value )
 
}

使用起来也是简单

$list = new SplDoublyLinkedList();
$list->push('a');
$list->push('b');
$list->push('c');
 
$list->unshift('top');
$list->shift();
 
print_r(array(
  'pop' => $list->pop(),
  'count' => $list->count(),
  'isEmpty' => $list->isEmpty(),
  'bottom' => $list->bottom(),
  'top' => $list->top()
));
 
$list->setIteratorMode(SplDoublyLinkedList::IT_MODE_FIFO);
print_r($list->getIteratorMode());
 
for($list->rewind(); $list->valid(); $list->next()) {
  echo $list->current().PHP_EOL;
}
 
print_r($a = $list->serialize());
//print_r($list->unserialize($a));
 
$list->offsetSet(0,'new one');
$list->offsetUnset(0);
print_r(array(
  'offsetExists' => $list->offsetExists(4),
  'offsetGet' => $list->offsetGet(0),
 
));
print_r($list);
PHP 相关文章推荐
PHP.MVC的模板标签系统(二)
Sep 05 PHP
如何利用php+mysql保存和输出文件
Oct 09 PHP
PHP中ADODB类详解
Mar 25 PHP
PHP __autoload()方法真的影响性能吗?
Mar 30 PHP
php 多关键字 高亮显示实现代码
Apr 23 PHP
php将session放入memcached的设置方法
Feb 14 PHP
PHP引用(&)各种使用方法实例详解
Mar 20 PHP
查找php配置文件php.ini所在路径的二种方法
May 26 PHP
jQuery+Ajax+PHP“喜欢”评级功能实现代码
Oct 08 PHP
Yii 2中的load()和save()示例详解
Aug 03 PHP
Thinkphp5.0框架的Db操作实例分析【连接、增删改查、链式操作等】
Oct 11 PHP
php实现简易计算器
Aug 28 PHP
php实现每天自动变换随机问候语的方法
May 12 #PHP
PHP 数据结构队列(SplQueue)和优先队列(SplPriorityQueue)简单使用实例
May 12 #PHP
php对象和数组相互转换的方法
May 12 #PHP
PHP SPL标准库之数据结构堆(SplHeap)简单使用实例
May 12 #PHP
php对数组内元素进行随机调换的方法
May 12 #PHP
PHP SplObjectStorage使用实例
May 12 #PHP
PHP中预定义的6种接口介绍
May 12 #PHP
You might like
新手学PHP之数据库操作详解及乱码解决!
2007/01/02 PHP
php中用数组的方法设置cookies
2011/04/21 PHP
解决php使用异步调用获取数据时出现(错误c00ce56e导致此项操作无法完成)
2013/07/03 PHP
php中session使用示例
2014/03/29 PHP
实现PHP框架系列文章(6)mysql数据库方法
2016/03/04 PHP
PHP反射机制原理与用法详解
2017/02/15 PHP
PHP用户注册邮件激活账户的实现代码
2017/05/31 PHP
JS控制表格隔行变色
2006/06/26 Javascript
用js实现控件的隐藏及style.visibility的使用
2013/06/14 Javascript
showModalDialog在谷歌浏览器下会返回Null的解决方法
2013/11/27 Javascript
14款经典网页图片和文字特效的jQuery插件-前端开发必备
2015/08/25 Javascript
avalon js实现仿google plus图片多张拖动排序附源码下载
2015/09/24 Javascript
BootstrapTable与KnockoutJS相结合实现增删改查功能【二】
2016/05/10 Javascript
用Nodejs搭建服务器访问html、css、JS等静态资源文件
2017/04/28 NodeJs
JS实现的简单表单验证功能完整实例
2017/10/14 Javascript
vue+axios+element ui 实现全局loading加载示例
2018/09/11 Javascript
NodeJs操作MongoDB教程之分页功能以及常见问题
2019/04/09 NodeJs
fastadmin中调用js的方法
2019/05/14 Javascript
js逆向解密之网络爬虫
2019/05/30 Javascript
js滚轮事件 js自定义滚动条的实现
2020/01/18 Javascript
Vue实现手机计算器
2020/08/17 Javascript
OpenLayer3自定义测量控件MeasureTool
2020/09/28 Javascript
微信小程序实现锚点跳转
2020/11/23 Javascript
python人人网登录应用实例
2014/09/26 Python
Python中处理unchecked未捕获异常实例
2015/01/17 Python
python实现随机梯度下降法
2020/03/24 Python
Django objects的查询结果转化为json的三种方式的方法
2018/11/07 Python
python 魔法函数实例及解析
2019/09/25 Python
wxpython绘制圆角窗体
2019/11/18 Python
JSF面试题:如何管量web层中的Bean,用什么标签。如何通过jsp页面与Bean绑定在一起进行处理?
2012/10/05 面试题
东方通信股份有限公司VC面试题
2014/08/27 面试题
怎么样写好简历中的自我评价
2013/10/25 职场文书
安全负责人任命书
2014/06/06 职场文书
安全知识竞赛主持词
2015/06/30 职场文书
nginx简单配置多个server的方法
2021/03/31 Servers
Python实现老照片修复之上色小技巧
2021/10/16 Python