码迷,mamicode.com
首页 > Web开发 > 详细

PHP双向循环链表代码

时间:2016-10-02 19:28:19      阅读:126      评论:0      收藏:0      [点我收藏+]

标签:

<?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双向循环链表代码

标签:

原文地址:http://www.cnblogs.com/hzhblog/p/5927822.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!