【问题标题】:String Replacement Combinations字符串替换组合
【发布时间】:2013-01-28 07:07:13
【问题描述】:

所以我有一个字符串'1xxx1',我想用一个字符替换一定数量(也许全部都没有)的x,比如说'5'。我想要字符串的所有可能组合(...可能是排列),其中 x 被替换或保留为 x。我希望将这些结果存储在一个列表中。

所以想要的结果是

>>> myList = GenerateCombinations('1xxx1', '5')
>>> print myList
['1xxx1','15xx1','155x1','15551','1x5x1','1x551','1xx51']

显然,我希望它能够处理任意长度的字符串和任意数量的 x,并且能够替换任意数字。我尝试使用循环和递归来解决这个问题,但无济于事。任何帮助将不胜感激。

【问题讨论】:

    标签: python string combinations


    【解决方案1】:

    怎么样:

    from itertools import product
    
    def filler(word, from_char, to_char):
        options = [(c,) if c != from_char else (from_char, to_char) for c in word]
        return (''.join(o) for o in product(*options))
    

    给了

    >>> filler("1xxx1", "x", "5")
    <generator object <genexpr> at 0x8fa798c>
    >>> list(filler("1xxx1", "x", "5"))
    ['1xxx1', '1xx51', '1x5x1', '1x551', '15xx1', '15x51', '155x1', '15551']
    

    (请注意,您似乎缺少15x51。) 基本上,首先我们为源词中的每个字母列出所有可能的目标:

    >>> word = '1xxx1'
    >>> from_char = 'x'
    >>> to_char = '5'
    >>> [(c,) if c != from_char else (from_char, to_char) for c in word]
    [('1',), ('x', '5'), ('x', '5'), ('x', '5'), ('1',)]
    

    然后我们使用itertools.product 得到这些可能性的笛卡尔积并将结果连接在一起。

    对于奖励积分,修改以接受替换字典。 :^)

    【讨论】:

    • 欧拉 51 项目需要它。
    • 为什么要用大锤敲碎坚果?
    • @Sam:我不关注。 itertools.product 是 Python 中获取笛卡尔积的规范方式。
    • 也许,我是不关注的人。无论如何,尽管您的代码很优雅,但我相信,一个简单的迭代方法应该比计算笛卡尔积要快得多。
    • @Sam:最简单的迭代方法(例如在您删除的答案中的那个)不能扩展到更大的字符串,而更复杂的迭代方法基本上重新实现了itertools.product。我错过了什么?
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2014-09-28
    • 2016-08-22
    • 1970-01-01
    • 1970-01-01
    • 2012-04-26
    • 2017-06-29
    • 2014-03-21
    相关资源
    最近更新 更多