欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

[PHP] 数据结构-循环链表的PHP实现

程序员文章站 2022-05-04 14:02:11
1.将单链表中终端结点的指针端由空指针改为指向头结点,单循环链表,循环链表和单链表的主要差异就在于循环的判断条件上原来是判断p->next是否为空,现在则是p->next不等于头结点,则循环未结束 2.指向终端结点的尾指针代表该循环链表 3.创建循环链表关键是头结点指向自身,最后一个终端结点指向头结 ......

1.将单链表中终端结点的指针端由空指针改为指向头结点,单循环链表,循环链表和单链表的主要差异就在于循环的判断条件上
原来是判断p->next是否为空,现在则是p->next不等于头结点,则循环未结束


2.指向终端结点的尾指针代表该循环链表

3.创建循环链表关键是头结点指向自身,最后一个终端结点指向头结点

<?php
class node{
        public $data;
        public $next;
}
//创建一个链表
$linklist=new node();
//头结点指向自身
$linklist->next=$linklist;
$temp=$linklist;
for($i=1;$i<=10;$i++){
        $node=new node();
        $node->data="aaa{$i}";
        //最后一个结点指向头结点
        $node->next=$linklist;
        $temp->next=$node;
        $temp=$node;
}
//循环链表的遍历
function printlooplink($linklist){
        $p=$linklist;
        //头结点
        $head=$linklist;
        //如果下一个结点是头结点代表结束
        while($p->next!=$head){
                $p=$p->next;
                print_r($p->data."  ");
        }   
}


//循环链表的优势
function printlooplink3($linklist){
        //循环链表的优势,从第三个结点开始遍历,遍历全部链表
        $p=$linklist->next->next->next;
        $head=$linklist->next->next->next;
        while($p->next!=$head){
                $p=$p->next;
                print_r($p->data."  ");
        }   
}

printlooplink($linklist);
printlooplink3($linklist);