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双向循环链表代码的主要内容,如果未能解决你的问题,请参考以下文章