php单链表实现代码分享

5年以前  |  阅读数:351 次  |  编程语言:PHP 

本文实例为大家分享了php单链表的具体代码,供大家参考,具体内容如下


    <?php
    /**
     * 单链表
     */ 
    class Demo
    {
      private $id;
      public $name;
      public $next;

      public function __construct ($id = '', $name = '')
      {
        $this->id = $id;
        $this->name = $name;
      }

      static public function show ($head)
      {
        $cur = $head;
        while ($cur->next) {
          echo $cur->next->id,'###',$cur->next->name,'<br />';
          $cur = $cur->next;
        }
        echo '<hr />';
      }

      //尾插法
      static public function push ($head, $node)
      {
        $cur = $head;
        while (NULL != $cur->next) {
          $cur = $cur->next;
        }
        $cur->next = $node;
        return $head;
      }

      static public function insert($head, $node)
      {
        $cur = $head;
        while (NULL != $cur->next) {
          if ($cur->next->id > $node->id) {
            break;
          }
          $cur = $cur->next;
        }
        $node->next = $cur->next;
        $cur->next = $node;
        return $head;
      }

      static public function edit($head, $node)
      {
        $cur = $head;
        while (NULL != $cur->next) {
          if ($cur->next->id == $node->id) {
            break;
          }
          $cur = $cur->next;
        }
        $cur->next->name = $node->name;
        return $head;    
      }

      static public function pop ($head, $node)
      {
        $cur = $head;
        while (NULL != $cur->next) {
          if ($cur->next == $node) {
            break;
          }
          $cur = $cur->next;
        }
        $cur->next = $node->next;
        return $head;      
      }
    }

    $team = new Demo();
    $node1 = new Demo(1, '唐三藏');
    Demo::push($team, $node1);
    $node1->name = '唐僧';
    Demo::show($team);

    // Demo::show($team);
    $node2 = new Demo(2, '孙悟空');
    Demo::insert($team, $node2);
    // Demo::show($team);
    $node3 = new Demo(5, '白龙马');
    Demo::push($team, $node3);
    // Demo::show($team);
    $node4 = new Demo(3, '猪八戒');
    Demo::insert($team, $node4);
    // Demo::show($team);
    $node5 = new Demo(4, '沙和尚');
    Demo::insert($team, $node5);
    // Demo::show($team);
    $node4->name = '猪悟能';//php对象传引用,所以Demo::edit没有必要
    // unset($node4);
    // $node4 = new Demo(3, '猪悟能');
    // Demo::edit($team, $node4);
    Demo::pop($team, $node1);

    Demo::show($team);

以上就是本文的全部内容,希望对大家实现php单链表有所帮助。

 相关文章:
PHP分页显示制作详细讲解
SSH 登录失败:Host key verification failed
获取IMSI
将二进制数据转为16进制以便显示
获取IMEI
文件下载
贪吃蛇
双位运算符
PHP自定义函数获取搜索引擎来源关键字的方法
Java生成UUID
发送邮件
年的日历图
提取后缀名
在Zeus Web Server中安装PHP语言支持
让你成为最历害的git提交人
Yii2汉字转拼音类的实例代码
再谈PHP中单双引号的区别详解
指定应用ID以获取对应的应用名称
Python 2与Python 3版本和编码的对比
php封装的page分页类完整实例