ホームページ >バックエンド開発 >C++ >Knuth のアルゴリズムはどのようにして順列を効率的に生成できるのでしょうか?

Knuth のアルゴリズムはどのようにして順列を効率的に生成できるのでしょうか?

Barbara Streisand
Barbara Streisandオリジナル
2025-01-04 06:15:38614ブラウズ

How Can Knuth's Algorithm Generate Permutations Efficiently?

Knuth アルゴリズムを使用した高速順列生成

順列生成の最適化は、コンピューター サイエンスの基本的な問題です。これは、すべての順列を列挙するのに必要な時間が膨大になる可能性がある、大規模なデータセットを扱う場合に特に重要です。次のコード スニペットは、Knuth アルゴリズムとして知られる順列を生成するための効率的なアルゴリズムを示しています。

private static bool NextPermutation(int[] numList)
{
    // Find the largest index j such that a[j] < a[j + 1].
    int largestIndex = -1;
    for (int i = numList.Length - 2; i >= 0; i--)
    {
        if (numList[i] < numList[i + 1]) {
            largestIndex = i;
            break;
        }
    }

    // If no such index exists, the permutation is the last permutation.
    if (largestIndex < 0) return false;

    // Find the largest index l such that a[j] < a[l].
    int largestIndex2 = -1;
    for (int i = numList.Length - 1 ; i >= 0; i--) {
        if (numList[largestIndex] < numList[i]) {
            largestIndex2 = i;
            break;
        }
    }

    // Swap a[j] with a[l].
    int tmp = numList[largestIndex];
    numList[largestIndex] = numList[largestIndex2];
    numList[largestIndex2] = tmp;

    // Reverse the sequence from a[j + 1] up to and including the final element a[n].
    for (int i = largestIndex + 1, j = numList.Length - 1; i < j; i++, j--) {
        tmp = numList[i];
        numList[i] = numList[j];
        numList[j] = tmp;
    }

    return true;
}

このアルゴリズムは O(n^2) 時間で動作します。ここで、n は入力リスト内の要素の数を表します。計算を最小限に抑えるために、次のようないくつかの最適化が採用されています。 a[j 1].

    a[j] 一時変数を使用した要素の効率的な交換。
  • ミラー化されたスワッピングを使用した、a[j 1] から最後までのシーケンスの効率的な反転。
  • これらの最適化により、セット内の次の順列の効率的な生成が保証され、このアルゴリズムは次のことを必要とするアプリケーションに非常に適しています。高速な順列生成。

以上がKnuth のアルゴリズムはどのようにして順列を効率的に生成できるのでしょうか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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