ホームページ バックエンド開発 Golang Go で 2 つの文字列スライス間の違いを効率的に見つけるにはどうすればよいですか?

Go で 2 つの文字列スライス間の違いを効率的に見つけるにはどうすればよいですか?

Dec 08, 2024 pm 12:59 PM

How to Efficiently Find the Difference Between Two String Slices in Go?

2 つの文字列スライス間の違いを見つける

プログラミングでは、2 つのスライスの内容を比較するのが一般的なタスクです。この質問は、あるスライスには存在するが別のスライスには存在しない要素を特定し、それらの間の「違い」を効果的に見つけることに焦点を当てています。

望ましい結果は、最初のスライスからの一意の要素を含む新しいスライスを受け取ることです。 2番目には存在しません。たとえば、slice1 に ["foo", "bar", "hello"] が含まれ、slice2 に ["foo", "bar"] が含まれる場合、違いは ["hello"] になります。

マップを使用した簡単な解決策

この問題を解決するための信頼できるアプローチには、マップの利用が含まれます。 Go のマップは、ほぼ一定の時間計算量 O(1) で、効率的な検索操作を提供します。このアプローチを実装する方法は次のとおりです。

// difference returns the elements in `a` that aren't in `b`.
func difference(a, b []string) []string {
    mb := make(map[string]struct{}, len(b))
    for _, x := range b {
        mb[x] = struct{}{}
    }

    var diff []string
    for _, x := range a {
        if _, found := mb[x]; !found {
            diff = append(diff, x)
        }
    }

    return diff
}
ログイン後にコピー

説明

この関数は、2 つの文字列スライス a と b を入力として受け取ります。 b の各要素を空の構造体にマップするマップ mb を構築します。このマップは、O(1) ルックアップで b 内の要素の存在を効率的に判断するために使用されます。

その後、関数は a を反復処理し、各要素を mb に存在する要素と照合してチェックします。 a の要素が mb で見つからない場合、差分スライスに追加されます。

最後に、b には存在しない a の一意の要素を含む差分スライスが返されます。

以上がGo で 2 つの文字列スライス間の違いを効率的に見つけるにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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

ホットな記事タグ

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Go Language Packのインポート:アンダースコアとアンダースコアなしの違いは何ですか? Go Language Packのインポート:アンダースコアとアンダースコアなしの違いは何ですか? Mar 03, 2025 pm 05:17 PM

Go Language Packのインポート:アンダースコアとアンダースコアなしの違いは何ですか?

Beegoフレームワークのページ間で短期情報転送を実装する方法は? Beegoフレームワークのページ間で短期情報転送を実装する方法は? Mar 03, 2025 pm 05:22 PM

Beegoフレームワークのページ間で短期情報転送を実装する方法は?

GOでテスト用のモックオブジェクトとスタブを書くにはどうすればよいですか? GOでテスト用のモックオブジェクトとスタブを書くにはどうすればよいですか? Mar 10, 2025 pm 05:38 PM

GOでテスト用のモックオブジェクトとスタブを書くにはどうすればよいですか?

トレースツールを使用して、GOアプリケーションの実行フローを理解するにはどうすればよいですか? トレースツールを使用して、GOアプリケーションの実行フローを理解するにはどうすればよいですか? Mar 10, 2025 pm 05:36 PM

トレースツールを使用して、GOアプリケーションの実行フローを理解するにはどうすればよいですか?

MySQLクエリ結果リストをGO言語のカスタム構造スライスに変換する方法は? MySQLクエリ結果リストをGO言語のカスタム構造スライスに変換する方法は? Mar 03, 2025 pm 05:18 PM

MySQLクエリ結果リストをGO言語のカスタム構造スライスに変換する方法は?

GOのジェネリックのカスタムタイプ制約を定義するにはどうすればよいですか? GOのジェネリックのカスタムタイプ制約を定義するにはどうすればよいですか? Mar 10, 2025 pm 03:20 PM

GOのジェネリックのカスタムタイプ制約を定義するにはどうすればよいですか?

Go言語でファイルを便利に書く方法は? Go言語でファイルを便利に書く方法は? Mar 03, 2025 pm 05:15 PM

Go言語でファイルを便利に書く方法は?

GOの実際のパフォーマンスを正確に反映するベンチマークを作成するにはどうすればよいですか? GOの実際のパフォーマンスを正確に反映するベンチマークを作成するにはどうすればよいですか? Mar 10, 2025 pm 05:36 PM

GOの実際のパフォーマンスを正確に反映するベンチマークを作成するにはどうすればよいですか?

See all articles