2024-1-10
1.使用双端队列实现栈
2.枚举字符串中的所有字符
3.判断当前字符和栈顶元素是否匹配.如果匹配,则弹出栈顶元素,如果不匹配,则将当前字符入栈
4.在栈中预先放入一个空字符,这样就不需要在遍历字符串时判断栈是否为空了,最后返回栈的大小减一
public int minLength(String s) {
Deque<Character> stack = new ArrayDeque<>(); // 使用双端队列实现栈
stack.push(' '); // 在栈底添加一个空格作为哨兵元素
for (char c : s.toCharArray()) { // 枚举字符串中的所有字符
if ((c == 'B' && stack.peek() == 'A') || (c == 'D' && stack.peek() == 'C')) { // 判断当前字符和栈顶元素是否匹配
stack.pop(); // 如果匹配,则弹出栈顶元素
} else {
stack.push(c); // 如果不匹配,则将当前字符入栈
}
}
return stack.size() - 1; // 返回栈的大小减去哨兵元素的个数,即为最小长度
}