亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

雙鏈表如何在PHP項目中使用

發布時間:2020-12-23 15:12:54 來源:億速云 閱讀:121 作者:Leah 欄目:開發技術

今天就跟大家聊聊有關 雙鏈表如何在PHP項目中使用,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。

雙鏈表是一種重要的線性存儲結構,對于雙鏈表中的每個節點,不僅僅存儲自己的信息,還要保存前驅和后繼節點的地址。

雙鏈表如何在PHP項目中使用

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項目中使用有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

霍邱县| 潞西市| 安庆市| 淮北市| 丽水市| 盖州市| 宁夏| 堆龙德庆县| 万山特区| 康定县| 五大连池市| 娱乐| 菏泽市| 灵璧县| 太原市| 丹巴县| 安达市| 灵川县| 沙雅县| 斗六市| 涞源县| 乌审旗| 遂平县| 灵宝市| 南安市| 山东| 二连浩特市| 宁波市| 新巴尔虎右旗| 江口县| 新余市| 扎兰屯市| 朝阳区| 武穴市| 萝北县| 五台县| 来宾市| 漠河县| 红原县| 双辽市| 栖霞市|