数値のすべての順列セットの列挙
組み合わせ論の領域では、順列とは、指定されたセットの要素の順序付けされた配置を指します。 0 から 8 までの数値のセットが与えられた場合、課題は、各数値がセット内で 1 回だけ現れる、考えられるすべての順列を生成することです。
順列の計算
一度に k 個ずつ取得される、n 個の要素の置換数を計算する式は次のとおりです。
nPk = n! / (n - k)!
この例では、 n = 9 および k = 9 の場合、次のようになります。
9P9 = 9! = 362,880
したがって、指定されたセットの可能な置換は 362,880 通りあります。
PHP 実装
PHP でこれらの順列を生成する 1 つの方法は、再帰的メソッドを使用することです。アルゴリズム:
<?php pc_permute([0, 1, 2, 3, 4, 5, 7, 8]); function pc_permute($items, $perms = array()) { if (empty($items)) { print join(' ', $perms) . "\n"; } else { for ($i = count($items) - 1; $i >= 0; --$i) { $newitems = $items; $newperms = $perms; list($foo) = array_splice($newitems, $i, 1); array_unshift($newperms, $foo); pc_permute($newitems, $newperms); } } } ?>
サンプル出力
このコードを実行すると、次のサンプル順列が生成されます:
0 1 2 3 4 5 6 7 8 0 1 2 3 4 5 6 8 7 0 1 2 3 4 5 7 6 8 0 1 2 3 4 5 7 8 6 0 1 2 3 4 5 8 6 7 0 1 2 3 4 5 8 7 6 ...
以上が9 つの数値のセットにはいくつの順列が存在しますか?また、それらは PHP でどのように生成できますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。