SPL-双向链表

SplDoublyLinkedList类提供了双向链表的主要功能。

方法

add — 在指定的索引处添加/插入新值
bottom — 从双向链表的开始处查看节点
__construct — 构造一个新的双向链表
count — 计算双向链表中元素的数量。
current — 返回当前数组条目
getIteratorMode — 返回迭代的模式
isEmpty — 检查双向链表是否为空。
key — 返回当前节点的索引
next — 移动到下一个条目
offsetExists — 返回请求的$index是否存在
offsetGet — 返回指定$index的值
offsetSet — 将指定$ index的值设置为$newval
offsetUnset — 取消设置指定$index的值
pop — 从双向链表的末尾处弹出节点
prev — 移动到上一个条目
push — 在双向链表的末尾推一个元素
rewind — 回滚迭代器回到开始
serialize — 序列化存储
setIteratorMode — 设置迭代的模式
shift — 从双向链表的末尾窥探节点
top — 从双向链表的末尾查看节点
unserialize — 反序列化存储
unshift —在元素前面添加双向链表
valid — 检查双向链表是否包含更多的节点

示例1

<?php

$list = new SplDoublyLinkedList();
//从尾部压入4个元素
$list->push('A');
$list->push('C');
$list->push('C');
$list->push('D');

//先进先出
echo "FIFO (First In First Out) :" . PHP_EOL;
$list->setIteratorMode(SplDoublyLinkedList::IT_MODE_FIFO);
for ($list->rewind(); $list->valid(); $list->next()) {
    echo $list->current() . "\n";
}

//LIFO (先进后出)
echo "LIFO (Last In First Out) :" . PHP_EOL;
$list->setIteratorMode(SplDoublyLinkedList::IT_MODE_LIFO);
for ($list->rewind(); $list->valid(); $list->next()) {
    echo $list->current() . "\n";
}

执行结果如图:

Paste_Image.png

示例2

<?php

$dlist = new SplDoublyLinkedList();

//在列表的末尾插入数据
$dlist->push('c++');
$dlist->push('java');
$dlist->push('go');

//unshift会在列表顶部插入数据
$dlist->unshift("1 jsp");
$dlist->unshift("2 php");
$dlist->unshift("3 asp");

/*
列表数据:
3 asp
2 php
1 jsp
c++
java
go
*/

//--------------------------------------

//pop从列表的尾部删除一个元素
$dlist->pop();

/*
列表数据:
3 asp
2 php
1 jsp
c++
java
*/


//--------------------------------------

//shift()从列表顶部删除一个项目,
$dlist->shift();

/*
列表数据:
2 php
1 jsp
c++
java
*/


//--------------------------------------

//add的方法替换特定索引处的值,如果要替换不存在的项,将抛出异常
$dlist->add(3, "C#");

/*
列表数据:
2 php
1 jsp
c++
C#
java
*/


//--------------------------------------


//rewind()方法根据迭代器指向列表的首字母
//valid()方法检查列表是否有效
//next()指向列表中的下一个数据。
for ($dlist->rewind(); $dlist->valid(); $dlist->next()) {

    echo $dlist->current() . PHP_EOL;
}
echo PHP_EOL;
/*
列表数据:
2 php
1 jsp
c++
C#
java
*/

//默认先进先出,我们将遍历模式改为先进后出
$dlist->setIteratorMode(SplDoublyLinkedList::IT_MODE_LIFO);
for ($dlist->rewind(); $dlist->valid(); $dlist->next()) {

    echo $dlist->current() . PHP_EOL;
}
/*
列表数据:
java
C#
c++
1 jsp
2 php
*/

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,294评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,780评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,001评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,593评论 1 289
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,687评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,679评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,667评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,426评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,872评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,180评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,346评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,019评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,658评论 3 323
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,268评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,495评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,275评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,207评论 2 352

推荐阅读更多精彩内容