我写这个类来实现链表:PHP循环链表实现
class Node{
public $data;
public $link;
function __construct($data, $next = NULL){
$this->data = $data;
$this->link = $next;
}
}
class CircularLinkedList{
private $first;
private $current;
private $count;
function __construct(){
$this->count = 0;
$this->first = null;
$this->current = null;
}
function isEmpty(){
return ($this->first == NULL);
}
function push($data){
//line 30
$p = new Node($data, $this->first);
if($this->isEmpty()){
$this->first = $p;
$this->current = $this->first;
}
else{
$q = $this->first;
//line 38
while($q->link != $this->first)
$q = $q->link;
$q->link = $p;
}
$this->count++;
}
function find($value){
$q = $this->first;
while($q->link != null){
if($q->data == $value)
$this->current = $q;
$q = $q->link;
}
return false;
}
function getNext(){
$result = $this->current->data;
$this->current = $this->current->link;
return $result;
}
}
但是当我试图把一些价值,
$ll = new CircularLinkedList();
$ll->push(5);
$ll->push(6);
$ll->push(7);
$ll->push(8);
$ll->push(9);
$ll->push(10);
//$ll->find(7);
for($j=0;$j<=30;$j++){
$result = $ll->getNext();
echo $result."<br />";
}
脚本在第二推挂出并给出max_execution_time
错误。
它工作正常,如果我改变上面所示calss的两条线30和38,作为一个正常的LinkedList。 (通过删除到第一个节点的最后一个节点链接)。
那么这有什么问题,以及如何解决它?
UPDATE:通过改变push()
功能这一点,工作细如线性链表:
function push($data){
$p = new Node($data);
if($this->isEmpty()){
$this->first = $p;
$this->current = $this->first;
}
else{
$q = $this->first;
while($q->link != null)
$q = $q->link;
$q->link = $p;
}
$this->count++;
}
我的假设是你的*链接*是不正确的。因此第38行是无限循环。一些调试可能证明这一点。 –
我知道问题在第38行,但逻辑似乎正确。问题是如何调试它 – Aliweb
你检查了'SplDoublyLinkedList'和朋友吗?你可能不需要自己做这一切。可能只是扩展一个SPL类http://php.net/manual/en/class.spldoublylinkedlist.php – Kris