zoukankan      html  css  js  c++  java
  • 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实现链表》传送门:http://www.cnblogs.com/yydcdut/p/3777760.html

    转载请注明出处:http://www.cnblogs.com/yydcdut

  • 相关阅读:
    Convert、Parse、TryParse、(int)区别及可能引发性能问题
    重写、覆盖、重载、多态几个概念的区别分析
    计算机系统的硬件组成(转)
    如何选择Html.RenderPartial和Html.RenderAction
    位运算(转)
    Java程序员面试中的多线程问题
    请转到控制面板来配置或安装系统组件
    开篇
    DropDownList 不能有多个项被选定!
    有关rollup和cube的使用方法讨论
  • 原文地址:https://www.cnblogs.com/yydcdut/p/3782661.html
Copyright © 2011-2022 走看看