Python中的itertools.combinations(iterable, r)(关键词:itertools/combinations)

本文介绍了一个Python函数,该函数能够创建一个迭代器,用于生成指定序列的所有长度为r的子序列,并确保这些子序列按输入序列中的顺序排列且不包含重复元素。文中提供了两种实现方式并引用了Python itertools模块的相关资料。

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

创建一个迭代器,返回iterable中所有长度为r的子序列,返回的子序列中的项按输入iterable中的顺序排序 (不带重复)

def combinations(iterable, r):
     # combinations('ABCD', 2) --> AB AC AD BC BD CD
     # combinations(range(4), 3) --> 012 013 023 123
     pool = tuple(iterable)
     n = len(pool)
     if r > n:
         return
     indices = range(r)
     yield tuple(pool[i] for i in indices)
     while True:
         for i in reversed(range(r)):
             if indices[i] != i + n - r:
                 break
         else:
             return
         indices[i] += 1
         for j in range(i+1, r):
             indices[j] = indices[j-1] + 1
         yield tuple(pool[i] for i in indices)

#或者
def combinations(iterable, r):
     pool = tuple(iterable)
     n = len(pool)
     for indices in permutations(range(n), r):
         if sorted(indices) == list(indices):
             yield tuple(pool[i] for i in indices)

参考文献:
1. Python itertools模块详解 - 脚本之家
2. itertools - Python标准库

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值