色尼玛亚洲综合影院,亚洲3atv精品一区二区三区,麻豆freexxxx性91精品,欧美在线91

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

看了很久數(shù)據(jù)結(jié)構(gòu)但是沒有怎么用過,在網(wǎng)上看到了關(guān)于php的數(shù)據(jù)結(jié)構(gòu),學(xué)習(xí)了一下,與大家一起分享一下。

復(fù)制代碼 代碼如下:
class Hero
{
    public $no;//排名
    public $name;//名字
    public $next=null;//$next是一個(gè)引用,指向另外一個(gè)Hero的對(duì)象實(shí)例

    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();
//第一個(gè)
$hero = new Hero(1,'111');
//連接
$head->next = $hero;
//第二個(gè)
$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);

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

php技術(shù)PHP小教程之實(shí)現(xiàn)鏈表,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 萍乡市| 清水河县| 全椒县| 顺义区| 广安市| 珠海市| 阳高县| 兴山县| 上杭县| 顺义区| 穆棱市| 饶河县| 英吉沙县| 秀山| 柏乡县| 苏尼特右旗| 古蔺县| 白河县| 涿鹿县| 通城县| 巍山| 黔西| 石景山区| 聊城市| 井研县| 奉节县| 蓬安县| 涟源市| 余干县| 大田县| 镇巴县| 涟源市| 南投市| 江源县| 元谋县| 绿春县| 南华县| 松潘县| 盐津县| 永福县| 洛浦县|