在 Python (Powerset) 中获取集合的所有子集
使用文档中的 itertools
配方来获取集合的所有子集。
from itertools import chain, combinations
def powerset(iterable):
"powerset([1,2,3]) --> () (1,) (2,) (3,) (1,2) (1,3) (2,3) (1,2,3)"
s = list(iterable)
return chain.from_iterable(combinations(s, r) for r in range(len(s)+1))
# print(list(combinations([1, 2, 3], 2)))
my_set = {1, 2, 3}
# 👇️ [(), (1,), (2,), (3,), (1, 2), (1, 3), (2, 3), (1, 2, 3)]
print(list(powerset(my_set)))
powerset 配方可在文档的此部分中找到。
itertools.combinations()
方法采用可迭代和长度参数。
该方法从可迭代对象中返回长度为 N 的元素的子序列。
from itertools import combinations
# 👇️ [()]
print(list(combinations([1, 2, 3], 0)))
# 👇️ [(1,), (2,), (3,)]
print(list(combinations([1, 2, 3], 1)))
# 👇️ [(1, 2), (1, 3), (2, 3)]
print(list(combinations([1, 2, 3], 2)))
# 👇️ [(1, 2, 3)]
print(list(combinations([1, 2, 3], 3)))
最后一步是使用 chain.from_iterable
方法。
该方法从可迭代对象获取链接输入,例如 ['ABC', 'DEF'] 变为 A B C D E F。
from itertools import chain
# 👇️ [(), (1,), (2,), (3,), (1, 2), (1, 3), (2, 3)]
print(list(chain.from_iterable([
[()],
[(1,), (2,), (3,)],
[(1, 2), (1, 3), (2, 3)],
])))
chain.from_iterable()
方法返回一个链对象。 如有必要,使用list()
类将其转换为元组列表。
或者,我们可以定义自己的函数。
def powerset(iterable):
l = list(iterable)
result = [tuple()]
for item in l:
result += [tup + (item,) for tup in result]
return result
my_set = {1, 2, 3}
# [(), (1,), (2,), (1, 2), (3,), (1, 3), (2, 3), (1, 2, 3)]
print(powerset(my_set))
该函数将集合转换为列表并使用 for 循环遍历列表。
在每次迭代中,我们使用列表推导来迭代结果变量。 结果变量存储元组列表。
我们使用加法 +
运算符来组合两个元组列表。
print([()] + [(1, 2)]) # 👉️ [(), (1, 2)]
print((1, 2) + (3, 4)) # 👉️ (1, 2, 3, 4)
我们还使用运算符将两个元组的元素组合成一个元组。
选择哪种方法是个人喜好问题。 我会使用文档中的方法,因为它非常高效,经过尝试和测试。
相关文章
Python for 循环中的下一项
发布时间:2023/04/26 浏览次数:179 分类:Python
-
本文讨论了 Python 中的 for 循环以及如何通过使用 for 循环和示例来跳过列表的第一个元素。
Python While 循环用户输入
发布时间:2023/04/26 浏览次数:148 分类:Python
-
我们可以在 while 循环中使用 input() 函数来输入数据,直到在 Python 中满足某个条件。
在 Python 中将整数转换为罗马数字
发布时间:2023/04/26 浏览次数:87 分类:Python
-
本篇文章将介绍在 Python 中将整数转换为罗马数字。以下是一个 Python 程序的实现,它将给定的整数转换为其等效的罗马数字。
在 Python 中将罗马数字转换为整数
发布时间:2023/04/26 浏览次数:144 分类:Python
-
本文讨论如何在 Python 中将罗马数字转换为整数。 我们将使用 Python if 语句来执行此操作。 我们还将探讨在 Python 中将罗马数字更改为整数的更多方法。
在 Python 中读取 gzip 文件
发布时间:2023/04/26 浏览次数:70 分类:Python
-
本篇文章强调了压缩文件的重要性,并演示了如何在 Python 中使用 gzip 进行压缩和解压缩。
在 Python 中锁定文件
发布时间:2023/04/26 浏览次数:141 分类:Python
-
本文解释了为什么在 Python 中锁定文件很重要。 这讨论了当两个进程在没有锁的情况下与共享资源交互时会发生什么的示例,为什么在放置锁之前知道文件状态很重要,等等
在 Python 中将 PDF 转换为文本
发布时间:2023/04/26 浏览次数:196 分类:Python
-
在本教程中,我们将学习如何使用 Python 使用 PyPDF2、Aspose 和 PDFminer 将 PDF 文档转换为文本文件。
在 Python 中创建临时文件
发布时间:2023/04/26 浏览次数:53 分类:Python
-
本文讲解了tempfile库函数的四个子函数:TemporaryFile、NamedTemporaryFile、mkstemp、TemporaryDirectory。 每个部分都提供了适当的程序,以简化对概念的理解。