给出由小写字母组成的字符串 S,重复项删除操作会选择两个相邻且相同的字母,并删除它们。
在 S 上反复执行重复项删除操作,直到无法继续删除。
在完成所有重复项删除操作后返回最终的字符串。答案保证唯一。
示例:
输入:"abbaca"
输出:"ca"
解释:
例如,在 "abbaca" 中,我们可以删除 "bb" 由于两字母相邻且相同,这是此时唯一可以执行删除操作的重复项。之后我们得到字符串 "aaca",其中又只有 "aa" 可以执行重复项删除操作,所以最后的字符串为 "ca"。
提示:
1 <= S.length <= 20000
S 仅由小写英文字母组成。
解法一:
class Solution:
def removeDuplicates(self, S: str) -> str:
l = []
for i in S:
if not l:
l.append(i)
else:
if i == l[-1]:
l.pop()
else:
l.append(i)
return "".join(l)
【leetcode-python】1047. 删除字符串中的所有相邻重复项
最新推荐文章于 2023-07-29 22:33:50 发布
本文介绍了一种通过删除相邻重复字符来简化字符串的算法。该算法使用栈结构处理输入字符串,逐一检查每个字符,若当前字符与栈顶字符相同则移除栈顶字符,反之将当前字符压入栈中。这一过程不断重复直至遍历完整个字符串,最终返回栈中剩余字符构成的字符串。文章提供了一个具体示例,展示了如何将abbaca简化为ca。


940

被折叠的 条评论
为什么被折叠?



