PHP小教程之实现链表


Posted in PHP onJune 09, 2014

看了很久数据结构但是没有怎么用过,在网上看到了关于PHP的数据结构,学习了一下,与大家一起分享一下。

class Hero
{
    public $no;//排名
    public $name;//名字
    public $next=null;//$next是一个引用,指向另外一个Hero的对象实例    public function __construct($no='',$name='')
    {
        $this->no=$no;
        $this->name=$name;
    }
    static public function showList($head)
    {
        $cur = $head;
        while($cur->next!=null)
        {
            echo "排名:".$cur->next->no.",名字:".$cur->next->name."<br>";
            $cur = $cur->next;
        }
    }
    //普通插入
    static public function addHero($head,$hero)
    {
        $cur = $head;
        while($cur->next!=null)
        {
            $cur = $cur->next;
        }
        $cur->next=$hero;
    }
    //有序的链表的插入  
    static public function addHeroSorted($head,$hero)
    {
        $cur = $head;
        $addNo = $hero->no;
        while($cur->next->no <= $addNo)
        {
            $cur = $cur->next;
        }
        /*$tep = new Hero();
        $tep = $cur->next;
        $cur->next = $hero;
        $hero->next =$tep;*/
        $hero->next=$cur->next;
        $cur->next=$hero;
    }
    static public function deleteHero($head,$no)
    {
        $cur = $head;
        while($cur->next->no != $no && $cur->next!= null)
        {
            $cur = $cur->next;
        }
        if($cur->next->no != null)
        {
            $cur->next = $cur->next->next;
            echo "删除成功<br>"; 
        }
        else
        {
            echo "没有找到<br>"; 
        }
    }
    static public function updateHero($head,$hero)
    {
        $cur = $head;
        while($cur->next->no != $hero->no && $cur->next!= null)
        {
            $cur = $cur->next;
        }
        if($cur->next->no != null)
        {
            $hero->next = $cur->next->next;
            $cur->next = $hero;
            echo "更改成功<br>"; 
        }
        else
        {
            echo "没有找到<br>"; 
        }
    }
}

//创建head头
$head = new Hero();
//第一个
$hero = new Hero(1,'111');
//连接
$head->next = $hero;
//第二个
$hero2 = new Hero(3,'333');
//连接
Hero::addHero($head,$hero2);
$hero3 = new Hero(2,'222');
Hero::addHeroSorted($head,$hero3);
//显示
Hero::showlist($head);
//删除
Hero::deleteHero($head,4);
//显示
Hero::showlist($head);
//更改
$hero4=new Hero(2,'xxx');
Hero::updateHero($head,$hero4);
//显示
Hero::showlist($head);

有序的插入的话需要遍历一遍链表,链表的一些知识就不介绍了哈。这里主要分享一下代码。

PHP 相关文章推荐
用PHP动态创建Flash动画
Oct 09 PHP
php访问查询mysql数据的三种方法
Oct 09 PHP
php中处理模拟rewrite 效果
Dec 09 PHP
利用static实现表格的颜色隔行显示的代码
Sep 02 PHP
phpMyAdmin出现无法载入 mcrypt 扩展,请检查PHP配置的解决方法
Mar 26 PHP
Apache中php.ini的设置方法
Feb 28 PHP
PHP中error_log()函数的使用方法
Jan 20 PHP
php数组键名技巧小结
Feb 17 PHP
PHP单例模式详解及实例代码
Dec 21 PHP
laravel 5.4 + vue + vux + element的环境搭配过程介绍
Apr 26 PHP
thinkPHP3.2.2框架行为扩展及demo示例
Jun 19 PHP
php和nginx交互实例讲解
Sep 24 PHP
浅谈Eclipse PDT调试PHP程序
Jun 09 #PHP
教你如何在CI框架中使用 .htaccess 隐藏url中index.php
Jun 09 #PHP
PHP、Nginx、Apache中禁止网页被iframe引用的方法
Oct 01 #PHP
PHP遍历目录并返回统计目录大小
Jun 09 #PHP
php中替换字符串中的空格为逗号','的方法
Jun 09 #PHP
使用php批量删除数据库下所有前缀为prefix_的表
Jun 09 #PHP
PHP OPP机制和模式简介(抽象类、接口和契约式编程)
Jun 09 #PHP
You might like
基于mysql的bbs设计(三)
2006/10/09 PHP
php随机抽奖实例分析
2015/03/04 PHP
PHP防盗链的基本思想 防盗链的设置方法
2015/09/25 PHP
详解php用static方法的原因
2018/09/12 PHP
浅谈PHP进程管理
2019/03/08 PHP
使用Entrust扩展包在laravel 中实现RBAC的功能
2020/03/16 PHP
基于jQuery的烟花效果(运动相关)点击屏幕出烟花
2012/06/14 Javascript
javascript之Partial Application学习
2013/01/10 Javascript
jquery实现通用的内容渐显Tab选项卡效果
2015/09/07 Javascript
jQuery实现的鼠标经过时变宽的效果(附demo源码)
2016/04/28 Javascript
jQuery表格(Table)基本操作实例分析
2017/03/10 Javascript
Angular中的interceptors拦截器
2017/06/25 Javascript
详解.vue文件中style标签的几个标识符
2018/07/17 Javascript
Vue实现购物车详情页面的方法
2019/08/20 Javascript
Vue可自定义tab组件用法实例
2019/10/24 Javascript
vue+vant使用图片预览功能ImagePreview的问题解决
2020/04/10 Javascript
javascript实现支付宝滑块验证码效果
2020/07/24 Javascript
IDEA配置jQuery, $符号不再显示黄色波浪线的问题
2020/10/09 jQuery
Vue实现指令式动态追加小球动画组件的步骤
2020/12/18 Vue.js
学习python (2)
2006/10/31 Python
深入理解Python中变量赋值的问题
2017/01/12 Python
python入门之基础语法学习笔记
2020/02/08 Python
python实现打砖块游戏
2020/02/25 Python
会计实习自我鉴定
2013/12/04 职场文书
平面设计岗位职责
2013/12/14 职场文书
函授药学自我鉴定
2014/02/07 职场文书
企业办公室岗位职责
2014/03/12 职场文书
领导干部贪图享乐整改措施
2014/09/21 职场文书
公司股份合作协议书
2014/12/07 职场文书
大学生年度个人总结
2015/02/15 职场文书
学校百日安全活动总结
2015/05/07 职场文书
2015年中学总务处工作总结
2015/07/22 职场文书
公安干警正风肃纪心得体会
2016/01/15 职场文书
《植物妈妈有办法》教学反思
2016/02/23 职场文书
中学生打架《检讨书》范文
2019/08/12 职场文书
NodeJs使用webpack打包项目的方法详解
2022/02/28 NodeJs