迹忆客 专注技术分享

当前位置:主页 > 学无止境 > 编程语言 > Python >

在 Python (Powerset) 中获取集合的所有子集

作者:迹忆客 最近更新:2022/11/15 浏览次数:

使用文档中的 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)))

python 获取集合的所有子集

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)))

python itertools.combinations() 获取集合的所有子集

最后一步是使用 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)],
])))

python chain from_iterable 迭代对象获取链接输入

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)

我们还使用运算符将两个元组的元素组合成一个元组。

选择哪种方法是个人喜好问题。 我会使用文档中的方法,因为它非常高效,经过尝试和测试。

转载请发邮件至 1244347461@qq.com 进行申请,经作者同意之后,转载请以链接形式注明出处

本文地址:

相关文章

Python for 循环中的下一项

发布时间:2023/04/26 浏览次数:179 分类:Python

本文讨论了 Python 中的 for 循环以及如何通过使用 for 循环和示例来跳过列表的第一个元素。

Python While 循环用户输入

发布时间:2023/04/26 浏览次数:148 分类:Python

我们可以在 while 循环中使用 input() 函数来输入数据,直到在 Python 中满足某个条件。

Python 中的整数规划

发布时间:2023/04/26 浏览次数:193 分类:Python

本文介绍了整数规划和可用于解决混合整数规划问题的 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。 每个部分都提供了适当的程序,以简化对概念的理解。

扫一扫阅读全部技术教程

社交账号
  • https://www.github.com/onmpw
  • qq:1244347461

最新推荐

教程更新

热门标签

扫码一下
查看教程更方便