在Python中查找给定字符串的所有可能排列
生成给定输入字符串的所有可行排列的任务有一个简单的解决方案在Python中。为了开始这项任务,我们首先考虑输入字符串,我们将尝试对其进行重新排序。为了便于说明,我们以字符串 'stack' 为例:
x = 'stack'
我们的目标是通过重新排列 'stack' 的字符来创建 'stack' 的排列。
l=['stack','satck','sackt'.......]
传统上,人们可能会考虑迭代方法来解决这一挑战,包括随机选择和换位字符对以生成新的排列。然而,我们可以利用 itertools 模块提供的 permutations() 方法来简化我们的任务。正如其文档所示:
itertools.permutations(iterable[, r])
Return successive r length permutations of elements in the iterable.
在我们的场景中使用此方法要求我们遵守以下注意事项:
因此,为了获得我们想要的排列,我们采用以下方法:
from itertools import permutations
perms = [''.join(p) for p in permutations('stack')]
此方法产生以下排列:
['stack', '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']
如果我们在排列中遇到重复项,我们可以通过将数据重组为防止重复的格式来处理它们,例如集合:
perms = [''.join(p) for p in permutations('stacks')]
len(perms) # 720
len(set(perms)) # 360
长度(烫发)#720
len(设置(权限)) # 360 免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。
Copyright© 2022 湘ICP备2022001581号-3