PHP实现双链表删除与插入节点的方法示例

前端之家收集整理的这篇文章主要介绍了PHP实现双链表删除与插入节点的方法示例前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

@H_301_0@本文实例讲述了PHP实现双链表删除与插入节点的方法分享给大家供大家参考,具体如下:


@H_3010@<span style="font-size: medium">

概述:


@H
3010@双向链表也叫双链表,是链表的一种,它的每个数据结点中都有两个指针,分别指向直接后继和直接前驱。所以,从双向链表中的任意一个结点开始,都可以很方便地访问它的前驱结点和后继结点。一般我们都构造双向循环链表。


@H
301_0@<span style="font-size: medium">

实现代码


<div class="jb51code">
<pre class="brush:PHP;">
<?php
class node{
public $prev;
public $next;
public $data;
public function construct($data,$prev=null,$next=null){
$this->data=$data;
$this->prev=$prev;
$this->next=$next;
}
}
class doubleLinkList{
private $head;
public function
construct()
{
$this->head=new node("head",null,null);
}
//插入节点
public function insertLink($data){
$p=new node($data,null);
$q=$this->head->next;
$r=$this->head;
while($q){
if($q->data>$data){
$q->prev->next=$p;
$p->prev=$q->prev;
$p->next=$q;
$q->prev=$p;
}else{
$r=$q;$q=$q->next;
}
}
if($q==null){
$r->next=$p;
$p->prev=$r;
}
}
//从头输出节点
public function printFromFront(){
$p=$this->head->next;
$string="";
while($p){
$string.=$string?",":"";
$string.=$p->data;
$p=$p->next;
}
echo $string."
";
}
//从尾输出节点
public function printFromEnd(){
$p=$this->head->next;
$r=$this->head;
while($p){
$r=$p;$p=$p->next;
}
$string="";
while($r){
$string.=$string?",":"";
$string.=$r->data;
$r=$r->prev;
}
echo $string."
";
}
public function delLink($data){
$p=$this->head->next;
if(!$p)
return;
while($p){
if($p->data==$data)
{
$p->next->prev=$p->prev;
$p->prev->next=$p->next;
unset($p);
return;
}
else{
$p=$p->next;
}
}
if($p==null)
echo "没有值为{$data}的节点";
}
}
$link=new doubleLinkList();
$link->insertLink(1);
$link->insertLink(2);
$link->insertLink(3);
$link->insertLink(4);
$link->insertLink(5);
$link->delLink(3);
$link->printFromFront();
$link->printFromEnd();
$link->delLink(6);

@H_502_15@

@H_301_0@运行结果:

PHP;"> 1,2,4,5 5,1,head 没有值为6的节点

@H_502_15@

@H_301_0@更多关于PHP相关内容感兴趣的读者可查看本站专题:《》、《》、《》、《》、《》及《

@H_
301_0@希望本文所述对大家PHP程序设计有所帮助。

猜你在找的PHP相关文章