【问题标题】:How to generate combination of characters in a string at a particular position?如何在特定位置生成字符串中的字符组合?
【发布时间】:2023-03-09 14:38:01
【问题描述】:

我有一个字符串列表:

li = ['a', 'b', 'c', 'd']

在 Python 中使用以下代码,我为列表 li 生成了所有可能的字符组合,并得到了 256 个字符串的结果。

from itertools import product

li = ['a', 'b', 'c', 'd']

for comb in product(li, repeat=4):
    print(''.join(comb))

比如说,我知道li列表中字符串的第二个和第四个位置的字符是'b'和'c'。 所以结果将是一组只有 16 个字符串,即:

abac
abbc
abcc
abdc
bbac
bbbc
bbcc
bbdc
cbac
cbbc
cbcc
cbdc
dbac
dbbc
dbcc
dbdc

如何得到这个结果?有没有一种 Pythonic 方法来实现这一点? 谢谢。

编辑:我想要的列表 li 的大小是 a 到 z,repeat 的值是 13。当我尝试上面的代码时,编译器抛出内存错误!

【问题讨论】:

  • 包含测试的列表理解
  • 大声笑。但好消息是,我知道这 13 个字符中的 6 个。所以它会达到数百万!

标签: python string combinations itertools


【解决方案1】:

使用list comprehension:

from itertools import product

li = ['a', 'b', 'c', 'd']
combs = [list(x) for x in product(li, repeat=4)]
selected_combs = [comb for comb in combs if (comb[1] == 'b' and comb[3] == 'c')]
print(["".join(comb) for comb in selected_combs])
# ['abac', 'abbc', 'abcc', 'abdc', 'bbac', 'bbbc', 'bbcc', 'bbdc', 'cbac', 'cbbc', 'cbcc', 'cbdc', 'dbac', 'dbbc', 'dbcc', 'dbdc']

为了节省内存以防您不需要所有组合combs,您可以这样做:

li = ['a', 'b', 'c', 'd']
selected_combs = [comb for comb in product(li, repeat=4) if (comb[1] == 'b' and comb[3] == 'c')]
print(["".join(comb) for comb in selected_combs])

【讨论】:

  • 这行得通!谢谢。但是,如果重复是 12 并且 li 从 a 到 z,我的记忆会保留吗?
  • @raghhav 更新了答案。
【解决方案2】:
def permute(s):
  out = []
  if len(s) == 1:
    return s
  else:
    for i,let in enumerate(s):
      for perm in permute(s[:i] + s[i+1:]):
        out += [let + perm]
  return out
  
per=permute(['a', 'b', 'c', 'd'])
print(per)

你想要这个吗?

【讨论】:

  • 有些字母需要固定的条件在哪里?这根本没有回答问题......
猜你喜欢
  • 2021-06-24
  • 1970-01-01
  • 2020-12-01
  • 1970-01-01
  • 2016-05-27
  • 2011-12-02
  • 2017-09-17
  • 2012-12-01
  • 1970-01-01
相关资源
最近更新 更多