您正在寻找一种方法来从列表中生成所有可能的 2^N 组合15 个元素的列表,在保持原始顺序的同时容纳任意长度的组合。虽然涉及二进制表示的方法是一个可行的选择,但让我们探索一个更全面的解决方案。
不要依赖二进制表示,而是考虑使用 Python 标准库中的 itertools.combinations() 函数。该函数根据给定的可迭代生成给定长度的所有组合的序列。通过改变长度参数,您可以获得任何所需大小的组合。
以下 Python 代码演示了这种方法:
import itertools stuff = [1, 2, 3] # Loop through all possible lengths for L in range(len(stuff) + 1): # Generate combinations of length L for subset in itertools.combinations(stuff, L): print(subset)
此代码将生成中元素的所有 32,768 种可能的组合内容列表,无论其长度如何。
或者,对于更简化的解决方案,您可以使用 chain() 和 Combinations() 函数生成包含所有可能长度的所有组合的单个序列:
import itertools from itertools import chain, combinations def all_subsets(ss): return chain(*map(lambda x: combinations(ss, x), range(0, len(ss)+1))) for subset in all_subsets(stuff): print(subset)
此代码实现了相同的结果,但以更简洁且可以说更优雅的方式。
以上是如何在 Python 中生成列表元素的所有可能组合?的详细内容。更多信息请关注PHP中文网其他相关文章!