PHP小教程之实现双向链表


Posted in PHP onJune 12, 2014

看了很久数据结构但是没有怎么用过,在网上看到了关于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 相关文章推荐
PHP全概率运算函数(优化版) Webgame开发必备
Jul 04 PHP
浅析PHP substr,mb_substr以及mb_strcut的区别和用法
Jun 21 PHP
解析获取优酷视频真实下载地址的PHP源代码
Jun 26 PHP
解析file_get_contents模仿浏览器头(user_agent)获取数据
Jun 27 PHP
php的慢速日志引起的Mysql错误问题分析
May 13 PHP
Zend Framework页面缓存实例
Jun 25 PHP
PHP中让curl支持sock5的代码实例
Jan 21 PHP
php结合正则获取字符串中数字
Jun 19 PHP
php str_getcsv把字符串解析为数组的实现方法
Apr 05 PHP
php实现评论回复删除功能
May 23 PHP
ThinkPHP5.0框架验证码功能实现方法【基于第三方扩展包】
Mar 11 PHP
phpQuery解析HTML乱码问题(补充官网未列出的乱码解决方案)
Apr 01 PHP
PHP开源开发框架ZendFramework使用中常见问题说明及解决方案
Jun 12 #PHP
PHP命名空间(Namespace)简明教程
Jun 11 #PHP
PHP APC配置文件2套和参数详解
Jun 11 #PHP
PHP捕获Fatal error错误的方法
Jun 11 #PHP
PHP独立Session数据库存储操作类分享
Jun 11 #PHP
php调用nginx的mod_zip模块打包ZIP文件
Jun 11 #PHP
php+ajax导入大数据时产生的问题处理
Jun 11 #PHP
You might like
杏林同学录(二)
2006/10/09 PHP
PHP三层结构(上) 简单三层结构
2010/07/04 PHP
php URL跳转代码 减少外链
2011/06/25 PHP
本地机apache配置基于域名的虚拟主机详解
2013/08/10 PHP
百度地图经纬度转换到腾讯地图/Google 对应的经纬度
2015/08/28 PHP
php+redis实现多台服务器内网存储session并读取示例
2017/01/12 PHP
PHP实现给定一列字符,生成指定长度的所有可能组合示例
2019/06/22 PHP
RR vs IO BO3 第一场2.13
2021/03/10 DOTA
JavaScript Konami Code 实现代码
2009/07/29 Javascript
jQuery之浮动窗口实现代码(两种方法)
2010/09/08 Javascript
namespace.js Javascript的命名空间库
2011/10/11 Javascript
如何使用jquery动态加载js,css文件实现代码
2013/04/03 Javascript
javascript+canvas制作九宫格小程序
2014/12/28 Javascript
javascript自动生成包含数字与字符的随机字符串
2015/02/09 Javascript
基于jQuery实现仿51job城市选择功能实例代码
2016/03/02 Javascript
jquery单击文字或图片内容放大并居中显示
2017/06/23 jQuery
Nodejs模块载入运行原理
2018/02/23 NodeJs
Vue之mixin全局的用法详解
2018/08/22 Javascript
JS实现页面跳转与刷新的方法汇总
2019/08/30 Javascript
javascript合并两个数组最简单的实现方法
2019/09/14 Javascript
JS页面获取 session 值,作用域和闭包学习笔记
2019/10/16 Javascript
原生js实现随机点名功能
2019/11/05 Javascript
微信小程序纯文本实现@功能
2020/04/08 Javascript
[43:51]2014 DOTA2国际邀请赛中国区预选赛 Dream Times VS TongFu
2014/05/22 DOTA
[01:02:54]完美世界DOTA2联赛PWL S2 FTD vs GXR 第一场 11.22
2020/11/26 DOTA
在python中的socket模块使用代理实例
2014/05/29 Python
简单介绍Python中的JSON使用
2015/04/28 Python
Python2和Python3中print的用法示例总结
2017/10/25 Python
pygame实现成语填空游戏
2019/10/29 Python
Python调用SMTP服务自动发送Email的实现步骤
2021/02/07 Python
Capitol Lighting的1800lighting.com:住宅和商业照明
2019/04/10 全球购物
毕业生自荐书模版
2014/01/04 职场文书
执行总经理岗位职责
2014/02/03 职场文书
绩效管理实施方案
2014/03/19 职场文书
企业总经理助理岗位职责
2014/09/12 职场文书
八年级作文之一起的走过日子
2019/09/17 职场文书