假设我们有一个二进制字符串s,我们可以删除两个相邻的字母(如果它们不同)。最后,如果我们能够多次执行此操作,则必须找到可以得到的最小字符串的长度。
因此,如果输入类似于s =“ 1100011”,则输出将为1,因为删除“ 10”后,我们得到的是“ 10011”,然后再次删除“ 10”,它将为“ 011”,然后删除“ 01” ”,它将剩下1。
为了解决这个问题,我们将遵循以下步骤-
堆栈:=一个新列表
对于s中的每个c
堆栈中的弹出元素
将c推入堆栈
如果堆栈为空或堆栈顶部与c相同,则
否则,当栈顶与c不相同时,则
返回堆栈中的元素数
让我们看下面的实现以更好地理解-
class Solution: def solve(self, s): stack = [] for c in s: if not stack or stack[-1] == c: stack.append(c) elif stack[-1] != c: stack.pop() return len(stack) ob = Solution() print(ob.solve("1100011"))
"1100011"
输出结果
1