如果有10个词,我想从中取3个词,该怎么做?

liftword5个月前 (02-08)技术文章34

作者:Python进阶者

来源:Python爬虫与数据挖掘

一、前言

偶然的一次机会,在隔壁群看到一个粉丝问了一道Python实现排列组合基础问题,拿到Python白银交流群问了一下,下图是他的需求:

很明显是个排列组合的问题,直接计算组合结果:C(10,3)=(10×9×8)/(3×2×1)=720/6 =120,答案是120。

二、实现过程

这里【瑜亮老师】直接给了一个代码,如下所示。

from itertools import combinations
word = ['鲁班七号', '鲁班', '鲁班大师', '甄姬', '安琪拉', '王昭君', '韩信', '孙悟空', '程咬金', '猪八戒']
res = [i for i in combinations(word, 3)]
print(res)
print(len(res))

运行结果如下图所示:

可以看到运行的结果最后得到的也是120,和手动计算的一致。

后来【const GF = null】自己也给了一个代码,如下图所示:

这个方法也不错,不过需要提前把排列组合的顺序算出来才行。

后来【瑜亮老师】补充了一个方法,代码如下所示:

word = ['鲁班七号', '鲁班', '鲁班大师', '甄姬', '安琪拉', '王昭君', '韩信', '孙悟空', '程咬金', '猪八戒']
res = [[i, j, k] for i in word[:] for j in word[word.index(i)+1:] for k in word[word.index(j)+1:]]
print(res)
print(len(res))

运行结果如下图所示:

这个方法是用列表推导式+列表切片+index,也是能实现的,改用range(len)也是一样的意思,其实就是3层循环,具体的层级如下所示:

res = []
for i in word[:]:
    for j in word[word.index(i)+1:]:
        for k in word[word.index(j)+1:]:
            res.append([i, j, k])
print(res)

运行结果如下图所示:

总之,完美地解决粉丝的问题啦!

不过话说回来,有现成的模块,直接用就行了,数据量一旦比较大的话,就难顶了,推荐第一种方法!

三、总结

大家好,我是进阶者。这篇文章主要盘点了一个Python实现排列组合的问题,文中针对该问题给出了具体的解析和代码实现,帮助粉丝顺利解决了问题。

相关文章

林俊杰的元宇宙房地产塌房,周杰伦站台的NFT稀碎

萧箫 发自 凹非寺量子位 | 公众号 QbitAI元宇宙房产和NFT暴跌,明星也拦不住。林俊杰花50多万元在元宇宙买下的三块虚拟地产暴降80%,跌到9万多元。这些地产如今访问量几乎为零,周围也完全没有...

python经典算法实践:回溯算法backtrack

回溯算法导读回溯法(back tracking)(探索与回溯法)是一种选优搜索法,又称为试探法,按选优条件向前搜索,以达到目标。但当探索到某一步时,发现原先选择并不优或达不到目标,就退回一步重新选择,...

2-1,0基础学Python之 break退出循环、 continue继续循环 多重循

用 for 循环或者 while 循环时,如果要在循环体内直接退出循环,可以使用 break 语句。比如计算1至100的整数和,我们用while来实现:sum = 0 x = 1 while True...

媳妇怀胎十月,我起名也用了十个月!太难了

本人姓袁,得知媳妇怀孕后就开始考虑——娃以后叫什么名字?0.5、给宝宝起个好名前,我得先把自己微信QQ名“好名都让狗占了”给改了。 0.6、百度抖音上一搜一大把,但好听点的名字,总感觉会是重名重灾区。...

12岁男孩一个暑假卖NFT「表情包」赚了250万

梦晨 发自 凹非寺量子位 报道 | 公众号 QbitAI12岁男孩在暑假里画了一系列画,在区块链上以NFT的形式出售,赚到的虚拟货币价值相当于250万人民币!这些画倒也不是什么精致的艺术品,只是一系列...

过年打麻将,只要掌握这点概率学原理,你能多胡好几盘

特别声明:本文为新华网客户端新媒体平台“新华号”账号作者上传并发布,仅代表作者观点,不代表新华号的立场及观点。新华号仅提供信息发布平台。明天就是除夕了,春节就在眼前,独乐乐不如众乐乐。如果要选择一种声...