[解決済み] リストの並べ換えをすべて生成するアルゴリズム?
質問
n個の要素を持つリストがあり、これらの要素の順序にはn!個の可能性があることを知っている。このリストのすべての可能な順序を生成するためのアルゴリズムとは何ですか?例:私はリスト[a、b、c]を持っています。このアルゴリズムは、[a, b, c], [a, c, b,], [b, a, c], [b, c, a], [c, a, b], [c, b, a]を返すでしょう。
ここで読んでいるのは http://en.wikipedia.org/wiki/Permutation#Algorithms_to_generate_permutations
しかし、ウィキペディアは説明が下手である。あまり理解できない。
どのように解決するのですか?
基本的に、左から右への各項目について、残りの項目のすべての順列が生成されます(そして、それぞれが現在の要素で追加されます)。これは、最後のアイテムに到達するまで再帰的に (または苦痛が好きなら反復的に) 行うことができ、その時点で可能な順序は 1 つだけとなります。
つまり、リスト [1,2,3,4] では、1 で始まるすべての並べ換えが生成され、次に 2 で始まるすべての並べ換え、次に 3、そして 4 となるわけです。
これは、4つの項目のリストの並べ換えを見つける問題から、3つの項目のリストに効果的に削減します。2項目リスト、1項目リストと減らしていった結果、すべての項目が見つかることになります。
3色のボールを使ってプロセスの順列を示す例。
(以下
https://en.wikipedia.org/wiki/Permutation#/media/File:Permutations_RGB.svg
-
https://commons.wikimedia.org/wiki/File:Permutations_RGB.svg
)
関連
-
[解決済み] クイックソートとヒープソートの比較
-
[解決済み] リストのリストからフラットなリストを作るには?
-
[解決済み] リスト内のアイテムのインデックスを検索する
-
[解決済み] リストが空かどうかを確認するにはどうすればよいですか?
-
[解決済み] Pythonのリストメソッドであるappendとextendの違いは何ですか?
-
[解決済み] 割り当て後にリストが予期せず変更されました。その理由と防止策を教えてください。
-
[解決済み] リストを均等な大きさの塊に分割するには?
-
[解決済み] リストの最後の要素を取得する方法
-
[解決済み] ゲーム「2048」の最適なアルゴリズムとは?
-
[解決済み] リストのすべての並べ換えを生成するには?
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン