题目
方法一:dp
int longestValidParentheses(string s) {
int ans = 0;
stack<int> sta;
sta.push(-1);
for(int i = 0;i < s.size();i ++)
{
if(s[i] == '(')sta.push(i);
else{
sta.pop();
if(sta.empty())
{
sta.push(i);
}else{
ans = max(ans,i - sta.top());
}
}
}
return ans;
}
方法二:栈
int longestValidParentheses(string s) {
s = ' ' + s;
int n = s.size();
vector<int> f(n,0);
for(int i = 2;i < n;i ++)
{
if(s[i] == ')'){
if(s[i-1] == '(')f[i] = f[i-2] + 2;
else if(s[i - f[i-1] - 1] == '(')f[i] = f[i - f[i-1] - 2] + f[i-1] + 2;
}
}
return *max_element(f.begin(),f.end());
}
方法三:贪心
int longestValidParentheses(string s) {
int left = 0,right = 0;
int ans = 0;
for(int i = 0;i < s.size();i ++)
{
if(s[i] == '(')left ++;
else right ++;
if(left == right) ans = max(ans,left * 2);
else if(right > left)right = left = 0;
}
left = 0,right = 0;
for(int i = s.size() - 1;i >= 0;i --)
{
if(s[i] == '(')left ++;
else right ++;
if(left == right) ans = max(ans,left * 2);
else if(right < left)right = left = 0;
}
return ans;
}
相关题目
void solve()
{
string s;cin >> s;
int maxLen = longestValidParentheses(s);
int left = 0,right = 0;
int maxNum = 1,num = 0;
for(int i = 0;i < s.size();i ++)
{
if(s[i] == '(')left ++;
else right ++;
if(right > left)right = left = 0;
else if(right == left && right*2 == maxLen)num ++;
}
maxNum = max(maxNum,num);
left = right = num = 0;
for(int i = s.size() - 1;i >= 0;i --)
{
if(s[i] == '(')left ++;
else right ++;
if(right < left)right = left = 0;
else if(right == left && right*2 == maxLen)num ++;
}
maxNum = max(maxNum,num);
cout << maxLen << " " << maxNum << endl;
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具