PHP小教程之实现双向链表
时间:2021-01-15
来源:互联网
标签:
看了很久数据结构但是没有怎么用过,在网上看到了关于PHP的数据结构,学习了一下,与大家一起分享一下。上一次分享了《PHP小教程之实现链表》,这次来补充说一下双向链表。
代码如下:
<?php
class Hero
{
public $pre=null;
public $no;
public $name;
public $next=null;
public function __construct($no='',$name='')
{
$this->no=$no;
$this->name=$name;
}
static public function addHero($head,$hero)
{
$cur = $head;
$isExist=false;
//判断目前这个链表是否为空
if($cur->next==null)
{
$cur->next=$hero;
$hero->pre=$cur;
}
else
{
//如果不是空节点,则安排名来添加
//找到添加的位置
while($cur->next!=null)
{
if($cur->next->no > $hero->no)
{
break;
}
else if($cur->next->no == $hero->no)
{
$isExist=true;
echo "<br>不能添加相同的编号";
}
$cur=$cur->next;
}
if(!$isExist)
{
if($cur->next!=null)
{
$hero->next=$cur->next;
}
$hero->pre=$cur;
if($cur->next!=null)
{
$hero->next->pre=$hero;
}
$cur->next=$hero;
}
}
}
//遍历
static public function showHero($head)
{
$cur=$head;
while($cur->next!=null)
{
echo "<br>编号:".$cur->next->no."名字:".$cur->next->name;
$cur=$cur->next;
}
}
static public function delHero($head,$herono)
{
$cur=$head;
$isFind=false;
while($cur!=null)
{
if($cur->no==$herono)
{
$isFind=true;
break;
}
//继续找
$cur=$cur->next;
}
if($isFind)
{
if($cur->next!=null)
{
$cur->next_pre=$cur->pre;
}
$cur->pre->next=$cur->next;
}
else
{
echo "<br>没有找到目标";
}
}
}
$head = new Hero();
$hero1 = new Hero(1,'1111');
$hero3 = new Hero(3,'3333');
$hero2 = new Hero(2,'2222');
Hero::addHero($head,$hero1);
Hero::addHero($head,$hero3);
Hero::addHero($head,$hero2);
Hero::showHero($head);
Hero::delHero($head,2);
Hero::showHero($head);
?>
以上就是PHP小教程之实现双向链表的全部内容,希望对你的学习有所帮助。
-
request.getParameter是从哪里获取数据? 时间:2025-11-18 -
简述TCP和UDP的主要区别及应用场景 时间:2025-11-18 -
Git和SVN的区别、优缺点和应用场景 时间:2025-11-18 -
Sqoop下载、安装与配置详解 时间:2025-11-18 -
Keepalived下载、配置、原理详解 时间:2025-11-18 -
Java.sql.Timestamp用法详解(构造方法、功能、方法摘要、实例代码) 时间:2025-11-18
今日更新
-
上学学生梗是什么梗揭秘00后校园爆笑黑话 看完秒懂学生党日常
阅读:18
-
优化币安交易设置避免爆仓的8个关键技巧
阅读:18
-
币安爆仓事件真相揭秘 官方沉默背后原因解析
阅读:18
-
烧? 烧饼是什么梗 揭秘网络爆笑热词背后的趣味故事
阅读:18
-
币安合约爆仓价异常疑云:用户需警惕计算误差风险
阅读:18
-
币安极端行情稳定性实测 交易体验深度解析
阅读:18
-
烧缸是什么梗梗姐姐?揭秘网络爆火方言梗,一秒get搞笑精髓!
阅读:18
-
烧梗是什么梗指网络流行语的爆火与快速更替现象 揭秘最新热梗来源和玩法
阅读:18
-
客服响应慢的5大原因及提速解决方案
阅读:18
-
币安在线客服快速联系指南 高效解决交易问题
阅读:18










