ホームページ >バックエンド開発 >Python チュートリアル >Python ですべての可能なセット パーティションを生成するにはどうすればよいでしょうか?
Python でパーティションを設定する
Python では、セットのパーティションは、その和集合が元のセットである互いに素なサブセットのコレクションです。配列 [1,2,3] について考えてみましょう。配列のすべての要素を使用して可能なすべての組み合わせを生成し、[[1]、[2]、[3]]、[[1,2]、[3]] などのパーティションを生成することを目指しています。
これを達成するために、私たちは再帰的アプローチを採用します。 「n-1」要素パーティションの場合、「n」番目の要素を組み込むときに、既存のサブセットに割り当てるか、新しいサブセットを作成するかの 2 つのオプションがあります。この徹底的なプロセスにより、すべての有効なパーティションが確実に生成されます。
たとえば、配列 [1,2,3] をパーティション化してみましょう。単一要素の基本ケースから始めて、[[1]] が得られます。次の要素に移動して、[1] パーティションの各サブセットに 2 を挿入し、結果は [[2], [1]] になります。また、新しいサブセット [[2,1]] も作成します。
引き続き再帰的に、要素 3 をパーティションに組み込みます。 [[2], [1]] パーティションの各サブセットに 3 を挿入し、[[3,2], [1]] と [[2,3], [1]] を生成します。また、新しいサブセット [[3,1],[2]] も作成します。
このパターンに従って、配列の可能なすべてのパーティションを徹底的に生成します。結果の出力は次のようになります:
[[1], [2], [3]] [[1,2], [3]] [[1], [2,3]] [[1,3], [2]] [[1,2,3]]
以上がPython ですべての可能なセット パーティションを生成するにはどうすればよいでしょうか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。