「労働者が自分の仕事をうまくやりたいなら、まず自分の道具を研ぎ澄まさなければなりません。」 - 孔子、「論語。陸霊公」
表紙 > プログラミング > Go チャネルで後入れ先出し (LIFO) 動作を実装するにはどうすればよいですか?

Go チャネルで後入れ先出し (LIFO) 動作を実装するにはどうすればよいですか?

2024 年 11 月 12 日に公開
ブラウズ:212

How to Implement Last-In, First-Out (LIFO) Behavior with Go Channels?

Go チャネルに対する後入れ先出し動作の実装

Go チャネルは自然に FIFO に従います (先入れ先出し) ) の動作は、深さ優先検索 (DFS) アルゴリズムの実装など、特定のシナリオには適していない可能性があります。この制限を克服するには、代替アプローチを検討することが重要です。

スタック データ構造の使用

残念ながら、Go チャネルはネイティブでは後入れ先着をサポートしていません。アウト (LIFO) 動作。回答で提案されているように、解決策の 1 つは、コンテナ/ヒープ パッケージを利用してスタック データ構造を作成することです。

ヒープを使用してスタックを実装する方法を示す簡単な例を次に示します。

import "container/heap"

type Stack []int

func (s Stack) Len() int           { return len(s) }
func (s Stack) Less(i, j int) bool { return s[i] > s[j] }    // Reverse the comparison for LIFO

// Initialize the stack
var stack Stack

// Push an element onto the stack
func Push(x int) { heap.Push(&stack, x) }

// Pop an element from the stack
func Pop() int {
    old := stack
    l := len(old)
    x := old[l-1]
    old = old[:l-1]
    heap.Init(&stack)
    for i := range old {
        heap.Push(&stack, old[i])
    }
    return x
}

スタックのような LIFO データ構造を実装することで、DFS アルゴリズムに必要な後入れ先出し動作を実現できます。

最新のチュートリアル もっと>

免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。

Copyright© 2022 湘ICP备2022001581号-3