java: add «32. Longest Valid Parentheses»
Signed-off-by: Matej Focko <me@mfocko.xyz>
This commit is contained in:
parent
dcefa07684
commit
6531d1a35f
1 changed files with 24 additions and 0 deletions
24
java/longest-valid-parentheses.java
Normal file
24
java/longest-valid-parentheses.java
Normal file
|
@ -0,0 +1,24 @@
|
|||
import java.util.Stack;
|
||||
|
||||
class Solution {
|
||||
public int longestValidParentheses(String s) {
|
||||
var longest = 0;
|
||||
var indices = new Stack<Integer>();
|
||||
|
||||
indices.push(-1);
|
||||
for (var i = 0; i < s.length(); ++i) {
|
||||
if (s.charAt(i) == '(') {
|
||||
indices.push(i);
|
||||
} else {
|
||||
indices.pop();
|
||||
if (indices.isEmpty()) {
|
||||
indices.push(i);
|
||||
} else {
|
||||
longest = Math.max(longest, i - indices.peek());
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return longest;
|
||||
}
|
||||
}
|
Loading…
Reference in a new issue