PHP双向循环链表代码

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了PHP双向循环链表代码相关的知识,希望对你有一定的参考价值。

<?php
class node{
    public $name;
    public $pre;
    public $next;
    public function __construct($name=""){
        $this->name=$name;
        $this->pre=null;
        $this->next=null;
    }
}
class myTwoWayCircleLinkList{
    public $header;
    public function __construct($name=null){
        $this->header=new node($name,null,null);
    }
    public function add(){
        $cur=$this->header;
        for($i=0;$i<24;$i++){
            $q=new node();
            $q->name=$i+1;
            $q->pre=$cur;
            $q->next=$cur->next;
            $cur->next=$q;
            $cur = $q;//每次循环完$cur就成了尾巴
        }  
        //将双向链表变为循环双向链表↓↓↓↓↓↓↓↓↓↓↓
        $cur->next=$this->header->next;
        $this->header->next->pre=$cur;
        //↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑
    }
    public function move($i){//正数向右,负数向左
        $cur=$this->header->next;
        if($i>0){
            do{
                $cur=$cur->pre;
            }while(--$i);
        }
        if($i<0){
            do{
                $cur=$cur->next;
            }while(++$i);
        }
        for($i=0;$i<24;$i++){
            echo "-".$cur->name."-";
            $cur=$cur->next;
        }       
    }
}
$header=new myTwoWayCircleLinkList();
$header->add();
$header->move(3);

以上是关于PHP双向循环链表代码的主要内容,如果未能解决你的问题,请参考以下文章

(java实现)双向循环链表

双向循环链表

带头双向循环链表 代码实现 review

数据结构——带头双向循环链表

数据结构开发(11):双向循环链表的实现

C语言实现双向非循环链表的逆序打印