solution.cpp 550 字节
Newer Older
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
#include <bits/stdc++.h>
using namespace std;
class Solution
{
public:
	int longestValidParentheses(string s)
	{
		stack<int> stk;
		int invalid = -1;
		int len = 0, max_len = 0;
		for (int i = 0; i < s.length(); i++)
		{
			if (s[i] == '(')
			{
				stk.push(i);
			}
			else
			{
				if (stk.empty())
				{
					invalid = i;
				}
				else
				{
					stk.pop();
					if (stk.empty())
					{
						max_len = max(i - invalid, max_len);
					}
					else
					{
						max_len = max(i - stk.top(), max_len);
					}
				}
			}
		}
		return max_len;
	}
};