标签:状态 href des while 最大 扫描 lse public 数列
这个题挺有意思,思路有些巧。硬上是不行的。
很明显,遇到括号匹配问题一定要从栈开始思考
说白了,这就是一个匹配消除的游戏,我给大家举个例子演示一波大家就看明白了,也就知道怎么做了
)(()()))( -> )(22))( -> )(4))( -> )6)( ,没有再可以匹配消除的块了,结束,答案为6
()()(() -> 22(2 -> 4(2 ,没有再可以匹配消除的块了,结束,答案为4
假设输入数列几位S
基本解法是维护一个栈,从S第一个元素开始一次扫描
class Solution {
public Stack<Integer> match(Stack<Integer> stack) {
Stack<Integer> newStack = new Stack<>();
int now = 0;
for (Integer i : stack) {
if (i == -1) {
if (now > 0) {
newStack.push(now);
now = 0;
}
newStack.push(-1);
} else if (i == -2) {
if (!newStack.empty() && newStack.peek() == -1) {
newStack.pop();
now += 2;
} else {
if (now > 0) {
newStack.push(now);
now = 0;
}
newStack.push(-2);
}
} else {
now += i;
}
}
if (now != 0) {
newStack.push(now);
}
return newStack;
}
public int longestValidParentheses(String s) {
Stack<Integer> stack = new Stack<>();
int ans = 0;
int max = 0;
for (int i = 0; i < s.length(); i++) {
if (s.charAt(i) == ‘(‘) {
stack.push(-1);
} else {
stack.push(-2);
}
}
int last_size = stack.size();
while (!((stack = match(stack)).size() == last_size)) {
last_size = stack.size();
}
while (!stack.empty()) {
Integer pop = stack.pop();
max = Math.max(pop, max);
}
return max;
}
}
标签:状态 href des while 最大 扫描 lse public 数列
原文地址:https://www.cnblogs.com/acbingo/p/9302261.html