PHP實現(xiàn)鏈表的定義與反轉(zhuǎn)功能示例
本文實例講述了PHP實現(xiàn)鏈表的定義與反轉(zhuǎn)功能。分享給大家供大家參考,具體如下:
PHP定義鏈表及添加、移除、遍歷等操作:
<?php class Node { private $Data;//節(jié)點數(shù)據(jù) private $Next;//下一節(jié)點 public function setData($value){ $this->Data=$value; } public function setNext($value){ $this->Next=$value; } public function getData(){ return $this->Data; } public function getNext(){ return $this->Next; } public function __construct($data,$next){ $this->setData($data); $this->setNext($next); } } class LinkList { private $header;//頭節(jié)點 private $size;//長度 public function getSize() { $i=0; $node=$this->header; while($node->getNext()!=null) { $i++; $node=$node->getNext(); } return $i; } public function setHeader($value){ $this->header=$value; } public function getHeader(){ return $this->header; } public function __construct(){ header("content-type:text/html; charset=utf-8"); $this->setHeader(new Node(null,null)); } /** *@author MzXy *@param $data--要添加節(jié)點的數(shù)據(jù) * */ public function add($data) { $node=$this->header; while($node->getNext()!=null) { $node=$node->getNext(); } $node->setNext(new Node($data,null)); } /** *@author MzXy *@param $data--要移除節(jié)點的數(shù)據(jù) * */ public function removeAt($data) { $node=$this->header; while($node->getData()!=$data) { $node=$node->getNext(); } $node->setNext($node->getNext()); $node->setData($node->getNext()->getData()); } /** *@author MzXy *@param 遍歷 * */ public function get() { $node=$this->header; if($node->getNext()==null){ print("數(shù)據(jù)集為空!"); return; } while($node->getNext()!=null) { print('['.$node->getNext()->getData().'] -> '); if($node->getNext()->getNext()==null){break;} $node=$node->getNext(); } } /** *@author MzXy *@param $data--要訪問的節(jié)點的數(shù)據(jù) * @param 此方法只是演示不具有實際意義 * */ public function getAt($data) { $node=$this->header->getNext(); if($node->getNext()==null){ print("數(shù)據(jù)集為空!"); return; } while($node->getData()!=$data) { if($node->getNext()==null){break;} $node=$node->getNext(); } return $node->getData(); } /** *@author MzXy *@param $value--需要更新的節(jié)點的原數(shù)據(jù) --$initial---更新后的數(shù)據(jù) * */ public function update($initial,$value) { $node=$this->header->getNext(); if($node->getNext()==null){ print("數(shù)據(jù)集為空!"); return; } while($node->getData()!=$data) { if($node->getNext()==null){break;} $node=$node->getNext(); } $node->setData($initial); } } $lists = new LinkList(); $lists -> add(1); $lists -> add(2); $lists -> get(); echo '<pre>'; print_r($lists); echo '</pre>'; ?>
反轉(zhuǎn)鏈表操作:
1. 常用的方法:左右交替,下一個結(jié)點保存,上一個結(jié)點替換該結(jié)點的下個結(jié)點。實現(xiàn)替換。
代碼:
function ReverseList($pHead) { // write code here if($pHead == null || $pHead->next == null){ return $pHead; } $p = $pHead; $q = $pHead->next; $pHead->next = null;//$pHead 變?yōu)槲仓羔? while($q){ $r = $q->next; $q->next = $p; $p = $q; $q = $r; } return $p; }
2. 使用遞歸方法。三個結(jié)點,頭結(jié)點,首節(jié)點,第二個結(jié)點。把首節(jié)點后面的所有結(jié)點當(dāng)成第二個結(jié)點,依次循環(huán)下去,由于要滿足 $pHead != null || $pHead->next != null
;所以不會出現(xiàn)遍歷不完的情況
function ReverseList($pHead) { // write code here if($pHead == null || $pHead->next == null){ return $pHead; } $res = ReverseList($pHead->next); $pHead->next->next = $pHead; $pHead->next = null; return $res; }
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《PHP數(shù)據(jù)結(jié)構(gòu)與算法教程》、《php程序設(shè)計算法總結(jié)》、《php字符串(string)用法總結(jié)》、《PHP數(shù)組(Array)操作技巧大全》、《PHP常用遍歷算法與技巧總結(jié)》及《PHP數(shù)學(xué)運算技巧總結(jié)》
希望本文所述對大家PHP程序設(shè)計有所幫助。
- php數(shù)組和鏈表的區(qū)別總結(jié)
- PHP雙向鏈表定義與用法示例
- php數(shù)據(jù)結(jié)構(gòu)之順序鏈表與鏈?zhǔn)骄€性表示例
- PHP實現(xiàn)合并兩個排序鏈表的方法
- php數(shù)組指針操作詳解
- php each 返回數(shù)組中當(dāng)前的鍵值對并將數(shù)組指針向前移動一步實例
- PHP7生產(chǎn)環(huán)境隊列Beanstalkd用法詳解
- php使用redis的有序集合zset實現(xiàn)延遲隊列應(yīng)用示例
- php+redis實現(xiàn)消息隊列功能示例
- PHP如何通過帶尾指針的鏈表實現(xiàn)''隊列''
相關(guān)文章
php+mysql+jquery實現(xiàn)簡易的檢索自動補全提示功能
這篇文章主要介紹了php+mysql+jquery實現(xiàn)簡易的檢索自動補全提示功能,涉及基于jQuery的ajax數(shù)據(jù)庫查詢與事件動態(tài)響應(yīng)相關(guān)操作技巧,需要的朋友可以參考下2017-04-04學(xué)習(xí)php設(shè)計模式 php實現(xiàn)抽象工廠模式
這篇文章主要介紹了php設(shè)計模式中的抽象工廠模式,使用php實現(xiàn)抽象工廠模式,感興趣的小伙伴們可以參考一下2015-12-12php性能優(yōu)化進階不要在for循環(huán)中操作DB
這篇文章主要為大家介紹了php性能優(yōu)化進階不要在for循環(huán)中操作DB,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-06-06PHP英文字母大小寫轉(zhuǎn)換函數(shù)小結(jié)
這篇文章主要介紹了幾個PHP英文字母大小寫轉(zhuǎn)換函數(shù),分為首字母大小寫轉(zhuǎn)換和所有字母大小寫轉(zhuǎn)換,需要的朋友可以參考下2014-05-05CURL的學(xué)習(xí)和應(yīng)用(附多線程實現(xiàn))
這篇文章主要介紹了CURL的安裝與多線程實現(xiàn)方法,需要的朋友可以參考下2013-06-06