ホームページ > バックエンド開発 > Golang > 1 行の逆方向リンクリスト

1 行の逆方向リンクリスト

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
リリース: 2024-02-09 09:18:19
転載
1043 人が閲覧しました

1 行の逆方向リンクリスト

php Xiaobian Yuzai は、一般的なデータ構造アルゴリズムである「行内逆リンク リスト」を紹介します。このアルゴリズムでは、リンク リスト内のノードの順序を逆にする必要があります。簡潔で効率的なコード実装により、リンク リストの順序を完全に逆転させて、この操作を 1 行で完了できます。このアルゴリズムは実際のプログラミングに非常に役立ち、データ処理とアルゴリズム設計の両方で重要な役割を果たします。この素晴らしいアルゴリズムについて一緒に学びましょう!

質問内容

go on leetcodeで1行を使った逆リンクリストの解決策を見つけました。機能しますが、実装方法がわかりません。

###それでおしまい:### リーリー

たとえば、リストを

[1->2->3->4->5->nil]

とします。 これが次のように機能することはわかっています:

    最初に実行します
  1. head.next = prev

    (head.next = nil、つまり今head = [1->nil])

  2. 次に、
  3. prev = head

    (このステップでは、前のステップの head と同様に、prev = [1->nil] になります)。

  4. head = head.next

    これは魔法です。 go の 2 番目のステップの prev には head = [1->nil] を使用しますが、このステップの後は head = [2->3-> ; 4->5->nil]

  5. したがって、
head != nil

の場合、反復され、2 番目のステップでは prev = [2->1->nil], head = [3- >4->5->nil] など。 この行は次のように表現できます:

リーリー

そうですか?なぜこうなった?

解決策

式の左側の変数は、その時点で式の右側の値に代入されます。これは言語の賢い使い方です。

わかりやすくするために、例を見てみましょう。

###設定###

これは私たちのリンクリストです: 1 -> 2 -> 3 -> 4 -> なし

関数が実行される前に、

先頭は *ノード 1

prev はゼロ (初期化されていません)
  • head.next は *ノード 2
  • です
  • ステップバイステップ
  • リーリー
  • 細かく見てみましょう、

prev (nil) = ヘッド (*ノード 1)

head (*ノード 1) = head.next (*ノード 2)
  • head.next (*ノード 2) = prev (nil)
  • 次の反復、
prev (*ノード 1) = ヘッド (*ノード 2)

head (*ノード 2) = head.next (*ノード 3)
  • head.next (*ノード 3) = prev (*ノード 1)
  • ###まとめ###
  • 基本的には、
  • head.next
  • を前のノードに戻し、prev と head を次のノードに移動します。

明確にするために、これを Go の教科書的なアルゴリズムと比較してください:

リーリー

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

ソース:stackoverflow.com
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート