python中的combinations和permutations

本文介绍Python中itertools库的组合(combinations)与排列(permutations)函数的使用方法,并通过实例展示了如何生成组合与排列,同时指出了处理重复元素时的特点。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

排列和组合是数论中的基本概念。在python中,实现了组合函数combinations 和 排列函数permutations。两个函数都在itertools包中。举例如下:

from itertools import combinations, permutations
data = [1,2,3,4]
from itertools import combinations, permutations
data=[1,2,3,4]
for combination in combinations(data,2):
    print(combination)

(1, 2)
(1, 3)
(1, 4)
(2, 3)
(2, 4)
(3, 4)
for permutation in permutations(data,2):
    print(permutation)

(1, 2)
(1, 3)
(1, 4)
(2, 1)
(2, 3)
(2, 4)
(3, 1)
(3, 2)
(3, 4)
(4, 1)
(4, 2)
(4, 3)

组合的个数为C24=6C42=6,排列的个数为A24=12A42=12
这两个函数都是基于下标的,而不是基于值的,也就是说,如果有重复,结果中不会去重。举例如下:

from itertools import combinations, permutations
data = [1,1,1,2]
for combination in combinations(data,2):
    print(combination)

(1, 1)
(1, 1)
(1, 2)
(1, 1)
(1, 2)
(1, 2)
for permutation in permutations(data,2):
    print(permutation)

(1, 1)
(1, 1)
(1, 2)
(1, 1)
(1, 1)
(1, 2)
(1, 1)
(1, 1)
(1, 2)
(2, 1)
(2, 1)
(2, 1)

结果没有去重。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

zhengjihao

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值