3138. 同位字符串连接的最小长度
给你一个字符串 s
,它由某个字符串 t
和若干 t
的 同位字符串 连接而成。
请你返回字符串 t
的 最小 可能长度。
同位字符串 指的是重新排列一个单词得到的另外一个字符串,原来字符串中的每个字符在新字符串中都恰好只使用一次。
示例 1:
输入:s = "abba"
输出:2
解释:
一个可能的字符串 t
为 "ba"
。
示例 2:
输入:s = "cdef"
输出:4
解释:
一个可能的字符串 t
为 "cdef"
,注意 t
可能等于 s
。
class Solution: def minAnagramLength(self, s: str) -> int: n = len(s) g = gcd(*Counter(s).values()) for times in range(g, 1, -1): if g % times: continue k = n // times t = sorted(s[:k]) if all(sorted(s[i - k: i]) == t for i in range(k * 2, n + 1, k)): return k return n