PHPでのリンクリストの実装

不言
不言オリジナル
2018-04-24 10:38:353817ブラウズ

この記事の内容は、PHP でのリンク リストの実装に関するものです。これは、必要な友人に参照してもらうために共有します。

今日からコードを書きましょう。は私が使用しているフォントです


上の 2 つの写真はまだかなり良く見えます。 ! !

console很好看,今天发现一个更喜欢的风格Source Code Pro


リンクリストの操作について話しましょう

node

まず、データを格納するノードクラスが必要です
  • <?phpnamespace LinkedList;class Node{
        /**
         * @var $data integer
         */
        public $data;    /**
         * 节点指向的下一个元素
         *
         * @var $next Node
         */
        public $next;    public function __construct(int $data = -1)
        {
            public function __construct(int $data = null)
            {
                // 初始化赋值 data,也可通过 $node->data = X; 赋值
                $this->data = $data;
            }
    }

    リンクリスト管理クラス(使用ノードデータを操作する)

操作クラスのコードが長すぎるので分割して解析します
  • ヘッダー挿入(比較的簡単なので先に説明します)

名前を聞くと、先頭からノードが挿入されていることがわかります
  • リンクリストが空の場合は、現在のノードを初期化します
  • リンクリストが空でない場合は、新しいノードをheadノード
  • public function insertHead(int $data) : bool{
        ///////////////////////////////////////////////////////////////////////////
        // +-----------+    +--------+    +--------+
        // |           |    |        |    |        |
        // | head node | +> |  node  | +> |  node  | +>
        // |           | |  |        | |  |        | |
        // |           | |  |        | |  |        | |
        // |    next   | |  |  next  | |  |  next  | |
        // +------+----+ |  +----+---+ |  +----+---+ |
        //        |      |       |     |       |     |
        //        +------+       +-----+       +-----+
        ///////////////////////////////////////////////////////////////
        //                   +-----------+    +--------+    +--------+
        //                   |           |    |        |    |        |
        //             +---> | head node | +> |  node  | +> |  node  | +>
        //             |     |           | |  |        | |  |        | |
        //             |     |           | |  |        | |  |        | |
        //             |     |    next   | |  |  next  | |  |  next  | |
        //             |     +------+----+ |  +----+---+ |  +----+---+ |
        //             |            |      |       |     |       |     |
        //  +--------+ |            +------+       +-----+       +-----+
        //  |        | |
        //  |new node| |
        //  |        | |
        //  |        | |
        //  |  next  | |
        //  +----+---+ |
        //       |     |
        //       +-----+
        //
        // 1. 实例化一个数据节点
        // 2. 使当前节点的下一个等于现在的头结点
        //        即使当前头结点是 null,也可成立
        // 3. 使当前节点成为头结点
        //        即可完成头结点的插入
        $newNode = new Node($data);    $newNode->next = $this->head;    $this->head = $newNode;    return true;
    }

    ノードを挿入(index=0が先頭ノード、順番に下に進み、その位置を超えて falseを返す)
  • public function insert(int $index = 0, int $data) : bool{
        // 头结点的插入, 当头部不存在,或者索引为0
        if (is_null($this->head) || $index === 0) {        return $this->insertHead($data);
        }    // 正常节点的插入, 索引从 0 开始计算
        // 跳过了头结点,从 1 开始计算
        $currNode = $this->head;    $startIndex = 1;    // 遍历整个链表,如果当前节点是 null,则代表到了尾部的下一个,退出循环
        for ($currIndex = $startIndex; ! is_null($currNode); ++ $currIndex) {        ////////////////////////////////////////////////////////////////////////////
            ///
            //   +--------+    +--------+    +-------------+    +--------+
            //   |        |    |        |    |             |    |        |
            //   |  node  | +> |currNode| +> |currNode next| +> |  node  | +>
            //   |        | |  |        | |  |             | |  |        | |
            //   |        | |  |        | |  |             | |  |        | |
            //   |  next  | |  |  next  | |  |     next    | |  |  next  | |
            //   +----+---+ |  +----+---+ |  +------+------+ |  +----+---+ |
            //        |     |       |     |         |        |       |     |
            //        +-----+       +-----+         +--------+       +-----+
            ////////////////////////////////////////////////////////////////////////////
            //   +--------+    +--------+                +-------------+    +--------+
            //   |        |    |        |                |             |    |        |
            //   |  node  | +> |currNode|             +> |currNode next| +> |  node  | +>
            //   |        | |  |        |             |  |             | |  |        | |
            //   |        | |  |        |             |  |             | |  |        | |
            //   |  next  | |  |  next  |             |  |     next    | |  |  next  | |
            //   +----+---+ |  +--------+             |  +------+------+ |  +----+---+ |
            //        |     |              +--------+ |         |        |       |     |
            //        +-----+              |        | |         +--------+       +-----+
            //                             |new node| |
            //                             |        | |
            //                             |        | |
            //                             |  next  | |
            //                             +----+---+ |
            //                                  |     |
            //                                  +-----+
            ////////////////////////////////////////////////////////////////////////////
            //
            //   +--------+    +--------+                +-------------+    +--------+
            //   |        |    |        |                |             |    |        |
            //   |  node  | +> |currNode|             +> |currNode next| +> |  node  | +>
            //   |        | |  |        |             |  |             | |  |        | |
            //   |        | |  |        |             |  |             | |  |        | |
            //   |  next  | |  |  next  |             |  |     next    | |  |  next  | |
            //   +----+---+ |  +----+---+             |  +------+------+ |  +----+---+ |
            //        |     |       |      +--------+ |         |        |       |     |
            //        +-----+       |      |        | |         +--------+       +-----+
            //                      +----> |new node| |
            //                             |        | |
            //                             |        | |
            //                             |  next  | |
            //                             +----+---+ |
            //                                  |     |
            //                                  +-----+
            //
            // 1. 当前索引等于传入参数的索引
            // 2. 实例化新数据节点
            // 3. 新节点的下一个指向当前节点的下一个节点
            // 4. 当前节点的下一个节点指向新节点
            if ($currIndex === $index) {            $newNode = new Node($data);            $newNode->next = $currNode->next;            $currNode->next = $newNode;            return true;
            }        // 移动到下一个节点
            $currNode = $currNode->next;
        }    return false;
    }

以上の2つが挿入の基本操作です。コード例を見てみましょう。

<?php
// 自动加载的代码就不贴了,直接在 githubrequire __DIR__.&#39;/../vendor/bootstrap.php&#39;;
// 实例化一个链表管理对象$manager = new \LinkedList\Manager();
// 8$manager->insertHead(8);
// 5 8$manager->insertHead(5);
// 1 5 8$manager->insertHead(1);
// 1 2 5 8$manager->insert(1, 2);
// false 节点元素不足 6 个$manager->insert(5, 4);
// 1 2 5 8 9$manager->insertEnd(9);
// 3$manager->find(8);
// 1 2 8 9$manager->delete(2);

Find

リンクされたリストの値を見つけるのも非常に簡単で、それを走査するだけです
  • /**
    * 查找链表的值中的索引
    * 成功返回索引值,找不到返回 -1
    *
    * @param int $data
    * @return int
    */public function find(int $data) : int{
        $currNode = $this->head;    // 查找还是很简单的,只要遍历一次链表,然后再判断值是否相等就可以了
        for ($i = 0; ! is_null($currNode); ++ $i) {        if ($currNode->data === $data) {            return $i;
            }        $currNode = $currNode->next;
        }    return -1;
    }

リンクされたリストを一度走査するだけで、等しい値を見つけ、見つかった場合はインデックス値を返します、見つからない場合は -1 を返します
  • 削除
  • /**
     * 删除链表的节点
     *
     * @param int $index
     * @return bool
     */public function delete(int $index) : bool{
        // 没有任何节点,直接跳过
        if (is_null($this->head)) {       return false;
        } elseif ($index === 0) {        // 头结点的删除
            $this->head = $this->head->next;
        }    // 这里的开始的索引是 1
        // 但当前节点指向的确实 头结点
        // 因为删除的时候必须标记删除的前一个节点
        // for 的判断是判断下一个节点是否为 null
        // $currNode 是操作的节点
        //    $currNode->next 是要删除的节点
        $startIndex = 1;    $currNode = $this->head;    for ($i = $startIndex; ! is_null($currNode->next); ++ $i) {        if ($index === $i) {            // 使当前节点等于要删除节点的下一个
                // 即可完成删除
                $currNode->next = $currNode->next->next;            break;
            }        $currNode = $currNode->next;
        }    return true;
    }
End

コードはgithubでホストされています
  • データ構造、二重リンクリスト、ツリーなどを学び続ける時間はあります! ! !
  • 関連する推奨事項:

php でリンク リストの逆順を実装する

PHP を使用して単一リンク リストを実装する

PHP で二重リンク リストを実装し、並べ替える方法

以上がPHPでのリンクリストの実装の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。