私はボードリストのリストを持っています。boards
。 boards
には、それぞれに同じ種類のボードを持つ多数のサブリストが含まれています。本質的に:[[...], [...], ...]
。各サブリストの項目を他のすべてのサブリスト(python)のすべての項目に一致させる
最初のサブリストが1で、2番目のサブリストが2であったとします.1の各要素を2の各要素と比較する必要があります。したがって、(1[0], 2[0]), (1[0], 2[1])...(1[0], 2[len(2)-1]);(1[0], 2[0])...
のペアが必要です。
の問題は、私はちょうどn個for
ループを行う私がないことができることを意味し、boards
にあるどのように多くのサブリスト分からないです。これは私が今持っているものです:
for sublist in boards:
for board in sublist:
for board_indices in itertools.permutations(range(len(sublist)), len(boards)):
matched_boards = [boards[a][j] for a, j in enumerate(i)]
しかし、私はそれを考えすぎていると思います。私はこれを行うための簡単でシンプルで読みやすい方法があると確信していますが、私はそれが何であるか分かりません。それはあなたが望むだけのペアをなら
あなたの質問は少し不明です。 'boards'のサブリストのすべてのペアからアイテムのすべてのペアを生成したいですか? –
また、投稿したコードはちょっと奇妙です。あなたの 'for board_indices'ループは' board_indices'で生成された順列に何もせず、あなたは定義されていない変数 'i'を持っています。 –
@ PM2Ringはい、そうです。また、 'i'変数を残して申し訳ありません。コードを読みやすくして、' i'を 'board_indices'に置き換えるのを忘れました。 – rassar