主要介绍栈的一个应用,之前做过类似的题目,这次彻底搞懂,记录之。。
找到最长匹配括号长度,这题比较难,之前刷题的时候就觉得,这次学到了。 比如说()()()(((
最长匹配括号长度为6,((())
最长匹配括号长度是4。
1.如果是左括号肯定是压栈(压入该左括号在串中的索引)。 2.如果是右括号: 那么就要分两种情况: 第一种情况是栈不为空,说明找到了匹配的左括号,那么记录当前匹配左括号的长度,并且并且弹栈,弹栈以后又分为两种情况: (1)栈为空,说明本次匹配完成,用当前索引减去start索引 (2)栈不为空,则当前匹配长度=当前索引-栈顶元素索引 第二种情况是栈为空,说明之前已经匹配完了,那么设置当前右括号的位置为新的匹配起点开始记录。
class Solution {public: int longestValidParentheses(string s) { stack<int> ss; int start = -1; int size=s.size(); int m=0; for(int i=0;i<size;++i) { if(s[i]=='(')//left push { ss.push(i); } else { if(ss.empty()) { start=i; } else { ss.pop(); if(ss.empty()) { m=max(i-start,m); } else { m=max(m,i-ss.top()); } } } } return m; }};新闻热点
疑难解答