程序以在 Python 中查找字符串中存在字谜的所有子字符串
假设我们有一个带有小写字母的字符串s。我们必须在s中找到所有在s中必须在不同位置的另一个子串,该子串是所取子串的变位词。我们必须按字典顺序找到一个子串列表。
因此,如果输入类似于s="abcba",那么输出将是['a','a','ab','abc','abcb','b','b','ba','bc','bcba','cb','cba']对于它们中的每一个,我们可以在字符串本身中找到不同的字谜。
示例
让我们看下面的实现来更好地理解
from collections import defaultdict def solve(s): res = [] L = len(s) for i in range(1, L + 1): smap = defaultdict(list) for j in range(L - i + 1): cs = s[j : j + i] k = "".join(sorted(cs)) smap[k].append(cs) for k, v in smap.items(): if len(v) >= 2: res.extend(v) return sorted(res) s = "abcba" print(solve(s))
输入
"abcba"输出结果
['a', 'a', 'ab', 'abc', 'abcb', 'b', 'b', 'ba', 'bc', 'bcba', 'cb', 'cba']