首页 > 编程 > PHP > 正文

PHP实现双向链表

2020-03-22 20:06:05
字体:
来源:转载
供稿:网友
  • 看了很久数据结构但是没有怎么用过,在网上看到了关于PHP的数据结构,学习了一下,与大家一起分享一下。上一次分享了链表,这次来补充说一下双向链表。

    简短不割

    <?php        html' target='_blank'>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);?>

    我是天王盖地虎的分割线

    出处:http://www.cnblogs.com/yydcdut

    PHP编程

    郑重声明:本文版权归原作者所有,转载文章仅为传播更多信息之目的,如作者信息标记有误,请第一时间联系我们修改或删除,多谢。

  • 发表评论 共有条评论
    用户名: 密码:
    验证码: 匿名发表