浅谈PHP数据结构之单链表

Posted wzzkaifa

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了浅谈PHP数据结构之单链表相关的知识,希望对你有一定的参考价值。

什么是链表?(依据百度词条查询而得)

链表是一种物理存储单元上非连续、非顺序的存储结构数据元素的逻辑顺序是通过链表中的指针链接次序实现的。链表由一系列结点(链表中每个元素称为结点)组成,结点能够在执行时动态生成。每个结点包含两个部分:一个是存储数据元素的数据域,还有一个是存储下一个结点地址的指针域。

经过查询资料和观摩了站点不同版本号的链表后。小弟自己尝试着写了一个php版本号的单链表,希望对大家理解链表有所帮助。

<?php
//定义结点
class Node{
    public $id;//结点ID
    public $data;//结点数据
    public $next;//指向下一结点
    public function __construct($id,$data){
        $this->id=$id;
        $this->data=$data;
        $this->next=NULL;
    }
}
class Linklist{
    private $head;//定义头结点
    public function __construct($id=0,$data=NULL){
        $this->head=new Node($id,$data);
    }
    //插入结点
    public function addNode($node){
        $head=$this->head;
        //插入之前检查ID是否冲突
        if($this->getNode($node->id)!=false){
            echo "您要插入的ID为".$node->id."数据为".$node->data."的结点已经存在该ID。请改动ID后重试<br>";
            return false;
        }
        while($head->next!=NULL){
            if($head->next->id >= $node->id){
                break;
            }
            $head=$head->next;
        }
        $node->next=$head->next;
        $head->next=$node;

    }

    //删除结点
    public function delNode($id){
        $head=$this->head;
        $temp=false;
        //注意。删除操作须要找到须要删除的前一个结点
        while($head->next != NULL){
            if($head->next->id==$id){
                $temp=true;
                break;
            }
            $head=$head->next;
        }
        if($temp==true){
            if($head->next->next==null){
                $head->next=NULL;
            }
            else
                $head->next=$head->next->next;
            
        return true;
    }
    else {
        echo ‘未找到id为‘.$id.‘的结点<br>‘;
    }
    }

    //获取链表
    public  function getList(){
        $head=$this->head;
        if($head->next==NULL){
            echo ‘该链表为空‘;
        }
        while($head->next !=NULL){
            if($head->id != 0)
            echo ‘ID为‘.$head->id.‘的结点中的数据为‘.$head->data.‘<br/>‘;
            $head=$head->next;
        }
            echo ‘ID为‘.$head->id.‘的结点中的数据为‘.$head->data;
    }

    //获取结点
    public function getNode($id){
        $head=$this->head;
        while($head !=NULL){
            if($head->id==$id)
                return $head->data;
            $head=$head->next;
        }
        return false;
    }

    //获取长度
    public function getLength(){
        $head=$this->head;
        $num=0;
        while($head->next !=NULL){
            $num++;
            $head=$head->next;
        }
        return $num;
    }
}
$a=new Linklist;
$a->addNode(new Node(1,"Hello Word"));
$a->addNode(new Node(2,3));
$a->addNode(new Node(2,11123));
$a->addNode(new Node(3,11123));
$a->getList();
$b=$a->getNode(3);
$c=$a->getLength();
var_dump($b);
var_dump($c);
?>

最后为測试代码,以下是測试结果:

技术分享

小弟初学。哪里不正确的希望大家能够包容下。给点建议。















































































































以上是关于浅谈PHP数据结构之单链表的主要内容,如果未能解决你的问题,请参考以下文章

数据结构与算法之PHP实现链表类(单链表/双链表/循环链表)

大话数据结构之php实现单链表

浅谈数据结构之链队列

浅谈PHP数据结构之队列

数据结构之单链表

数据结构线性表之实现单链表