给你一个字符串 s
,「k
倍重复项删除操作」将会从 s
中选择 k
个相邻且相等的字母,并删除它们,使被删去的字符串的左侧和右侧连在一起。
你需要对 s
重复进行无限次这样的删除操作,直到无法继续为止。
在执行完所有删除操作后,返回最终得到的字符串。
本题答案保证唯一。
示例 1:
输入:s = "abcd", k = 2
输出:"abcd"
解释:没有要删除的内容。
示例 2:
输入:s = "deeedbbcccbdaa", k = 3
输出:"aa"
解释:
先删除 "eee" 和 "ccc",得到 "ddbbbdaa"
再删除 "bbb",得到 "dddaa"
最后删除 "ddd",得到 "aa"
示例 3:
输入:s = "pbbcggttciiippooaais", k = 2
输出:"ps"
提示:
1 <= s.length <= 10^5
2 <= k <= 10^4
s
中只含有小写英文字母。
解题思路
这个问题是之前问题Leetcode 1047:删除字符串中的所有相邻重复项(超详细的解法!!!)的升级。实际上这个问题依旧是通过栈处理,栈中存放[字符,字符个数]
。我们遍历字符串的过程中判断当前遍历到的字符串是不是和栈顶的字符相同,如果相同栈顶字符个数加1
,接着需要判断此时的字符个数是不是k
,如果是的话,弹出栈顶元素;如果栈顶元素不是当前遍历到的元素,则将当前遍历到的元素添加到栈中。最后输出栈中元素即可。
class Solution:
def removeDuplicates(self, s: str, k: int) -> str:
st = [['#', 0]]
for c in s:
if st[-1][0] == c:
st[-1][1] += 1
if st[-1][1] == k:
st.pop()
else:
st.append([c, 1])
res = ""
for i, j in st:
res += i * j
return res
我将该问题的其他语言版本添加到了我的GitHub Leetcode
如有问题,希望大家指出!!!