-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy path32. Longest Valid Parentheses.cpp
55 lines (53 loc) · 1.74 KB
/
32. Longest Valid Parentheses.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
class Solution {
public:
int longestValidParentheses(string s) {
if(s.empty())
return 0;
stack<int>res;
int count=0,start=0;
for(int i=0;i<s.length();i++){
if(s[i]=='(')
res.push(i);
else{
if(res.empty())
start=0;// 这个地方很重要,如果单独出现‘)’,就需要判断
else{
int tem=res.top();res.pop();
if(res.empty()){
start+=i-tem+1;//他的意思是找最长的一段括号,如果中间有一对间隔的,再隔了一个,自然start=0
count=max(count,start);
}else{
count=max(count,i-res.top());// hard part
}
}
}
}
return count;
}
//注意体会两种特殊情况 "()()" "(())"
//出错根源在于"(())" 在res出栈后,如果不是空的,start+=i-tem+1; 这样会多加2
// 不会了啊,稍微会了一丢丢
class Solution {
public:
int longestValidParentheses(string s) {
int res=0, res_temp=0;
if(s.size()<=1) return res;
stack<int> st;
for(int i=0; i<s.size(); i++){
if(s[i]=='(') st.push(i);
else{
if(st.empty()) res_temp=0;
else{
int prev=st.top();st.pop();
if(st.empty()){
res_temp += (i-prev+1);
res=max(res, res_temp);
}else{
res = max(res, i-st.top());
}
}
}
}
return res;
}
};