在python中查找给定字符串的所有可能排列

在python中查找给定字符串的所有可能排列,第1张

在python中查找给定字符串的所有可能排列

itertools模块具有一个有用的方法,称为permutations()。该文件说:

itertools.permutations(iterable [,r])

返回迭代器中元素的连续r长度排列。

如果未指定r或为None,则r默认为可迭代的长度,并生成所有可能的全长置换

排列以字典顺序排序。因此,如果对输入的iterable进行排序,则将按排序顺序生成置换元组。

不过,您必须将排列的字母作为字符串连接起来。

>>> from itertools import permutations>>> perms = [''.join(p) for p in permutations('stack')]>>> perms

[“堆栈”,“ stakc”,“ stcak”,“ stcka”,“ stkac”,“ stkca”,“ satck”,“ satkc”,“
sactk”,“ sackt”,“ saktc”,“ sakct”,“
sctak’,’sctka’,’scatk’,’scakt’,’sckta’,’sckat’,’sktac’,’sktca’,’skatc’,’skact’,’skcta’,’skcat’,’tsack’
,“ tsakc”,“ tscak”,“ tscka”,“ tskac”,“ tskca”,“ tasck”,“ taskc”,“ tacsk”,“
tacks”,“ taksc”,“ takcs”,“ tcsak”,“
tcska,’tcask’,tcaks,’tcksa’,’tckas’,tksac’,’tksca’,’tkasc’,’tkacs’,’tkcsa’,’tkcas’,’astck’,’astkc”,“
asctk”,“ asckt”,“ asktc”,“ askct”,“ atsck”,“ atskc”,“ atcsk”,“ atcks”,“
atksc”,“ atkcs”,“ acstk”,“ acskt” ,“ actsk”,“ actks”,“ ackst”,“ ackts”,“
akstc”,“ aksct”,“ aktsc”,“ aktcs”,“ akcst”,“ akcts”,“ cstak”,“ cstka”,“
csatk”,“ csakt”,“ cskta”,“ cskat”,“ ctsak”,“ ctska”,“ ctask”,“ ctaks”,“
ctksa”,“ ctkas”,“ castk”,“ caskt”,“ catsk” ,“ catks”,“ cakst”,“ cakts”,“
cksta”,“ cksat”,“ cktsa”,“ cktas”,“ ckast”,“ ckats”,“ kstac”,“ kstca”,“
ksatc”,’ksact’,’kscta’,’kscat’,’ktsac’,’ktsca’,’ktasc’,’ktacs’,’ktcsa’,’ktcas’,’kastc’,’kasct’,’katsc’,’katcs
‘,’kacst’,’kacts’,’kcsta’,’kcsat’,’kctsa’,’kctas’,’kcast’,’kcats’]


如果您发现自己受到重复的困扰,请尝试将数据拟合到没有重复的结构中,例如

set

>>> perms = [''.join(p) for p in permutations('stacks')]>>> len(perms)720>>> len(set(perms))360

感谢@pst指出这不是我们传统上认为的类型转换,而是更多的对

set()
构造函数的调用。



欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5643584.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-16
下一篇 2022-12-16

发表评论

登录后才能评论

评论列表(0条)

保存