集合の順列を効率的に生成する
集合の順列を生成する問題では、最も効率的なアルゴリズムを見つけることが重要です。提供されたコードは高い効率を実現しますが、要求の厳しい計算では最適化が求められます。
提案された解決策: Knuth のアルゴリズム
Knuth のアルゴリズムは、順列を生成するための高効率なアプローチを提供します。これは 4 つの主なステップで動作します:
実装
Knuth のアルゴリズムを実装する提供されている C# コードを以下に示します。
private static bool NextPermutation(int[] numList) { // 1. Find the largest index j such that a[j] < a[j + 1]. If no such index exists, the permutation is the last permutation. var largestIndex = -1; for (var i = numList.Length - 2; i >= 0; i--) { if (numList[i] < numList[i + 1]) { largestIndex = i; break; } } // If no such index exists, return false indicating the last permutation. if (largestIndex < 0) return false; // 2. Find the largest index l such that a[j] < a[l]. Since j + 1 is such an index, l is well defined and satisfies j < l. var largestIndex2 = -1; for (var i = numList.Length - 1; i >= 0; i--) { if (numList[largestIndex] < numList[i]) { largestIndex2 = i; break; } } // 3. Swap a[j] with a[l]. var tmp = numList[largestIndex]; numList[largestIndex] = numList[largestIndex2]; numList[largestIndex2] = tmp; // 4. 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; }
速度最適化の考慮事項
向けさらに速度を最適化するには、次の点を考慮してください:
以上がKnuth のアルゴリズムはどのようにして集合順列を効率的に生成できるのでしょうか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。