一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - PHP教程 - PHP小教程之實現(xiàn)鏈表

PHP小教程之實現(xiàn)鏈表

2020-07-02 14:46PHP編程教程 PHP教程

php中沒有鏈表這種數(shù)據(jù)結構,可以通過數(shù)組來實現(xiàn)

看了很久數(shù)據(jù)結構但是沒有怎么用過,在網(wǎng)上看到了關于PHP的數(shù)據(jù)結構,學習了一下,與大家一起分享一下。

 

復制代碼 代碼如下:


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>";
        }
    }
}

 

//創(chuàng)建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);

 

有序的插入的話需要遍歷一遍鏈表,鏈表的一些知識就不介紹了哈。這里主要分享一下代碼。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 日本人啪啪 | 蜜月aⅴ免费一区二区三区 蜜桃影像传媒推广 | 日本人成动漫网站在线观看 | 国产精品视频2021 | 午夜AV内射一区二区三区红桃视 | 91大神第九部红酒气质女 | 91国内精品 | 日本高清中文字幕 | 骚虎最新网址 | 波多野结衣被绝伦强在线观看 | 日本老妇人乱视频 | 楚乔传第二部免费观看全集完整版 | 午夜国产在线 | 亚洲国产精品一区二区首页 | 人配人种视频xxxx | 四虎影视在线看免费 720p | 国产网站免费看 | 操一操影院 | 精品成人一区二区三区免费视频 | 四虎网站网址 | 国产精品不卡高清在线观看 | 男人天堂网页 | 18videossex性欧美69| 99成人国产精品视频 | chinese男性厕所撒尿合集 | 性xxxx中国老妇506070 | 双性肉文高h | 国产一区二区视频在线播放 | 91精品国产91久久 | 青草久久伊人 | 99影视在线视频免费观看 | 精品国产人成亚洲区 | 日韩无遮挡大尺度啪啪影片 | 华人亚洲欧美精品国产 | 久久精品国产亚洲AV热无遮挡 | 99热这里只有精品久久免费 | 午夜精品久久久久久久99蜜桃 | 国语刺激对白勾搭视频在线观看 | 国产精品色拉拉免费看 | 无码AV免费精品一区二区三区 | 国产91精选在线观看麻豆 |