当前位置:网站首页>LeetCode·32.最长有效括号·栈·动态规划
LeetCode·32.最长有效括号·栈·动态规划
2022-08-01 21:03:00 【小迅想变强】
链接:https://leetcode.cn/problems/longest-valid-parentheses/solution/by-xun-ge-v-h2qz/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
题目

示例
思路
解题思路
- 栈
具体做法是我们始终保持栈底元素为当前已经遍历过的元素中「最后一个没有被匹配的右括号的下标」,这样的做法主要是考虑了边界条件的处理,栈里其他元素维护左括号的下标:
- 对于遇到的每个‘(’ ,我们将它的下标放入栈中
- 对于遇到的每个 ‘)’ ,我们先弹出栈顶元素表示匹配了当前右括号:
如果栈为空,说明当前的右括号为没有被匹配的右括号,我们将其下标放入栈中来更新我们之前提到的「最后一个没有被匹配的右括号的下标」
如果栈不为空,当前右括号的下标减去栈顶元素即为「以该右括号为结尾的最长有效括号的长度」
我们从前往后遍历字符串并更新答案即可。
需要注意的是,如果一开始栈为空,第一个字符为左括号的时候我们会将其放入栈中,这样就不满足提及的「最后一个没有被匹配的右括号的下标」,为了保持统一,我们在一开始的时候往栈中放入一个值为 −1 的元素。
- 动态规划
结合题目,可以考虑尝试使用 动态规划 进行分析。这是一个 最值型 动态规划的题目。
动态规划题目分析的 4 个步骤:
- 确定状态
- 研究最优策略的最后一步
- 化为子问题
- 转移方程
- 根据子问题定义得到
- 初始条件和边界情况
- 计算顺序

具体实现
首先,我们定义一个 dp 数组,其中第 i 个元素表示以下标为 i 的字符结尾的最长有效子字符串的长度。当i为 ')'时分析对于位置括号情况即可。
代码
//栈
#define MAX(a , b) ((a) > (b) ? (a) : (b))
int longestValidParentheses(char * s){
int len = strlen(s);
int max = 0;
int str[len+1];//定义栈
int top = -1;
str[++top] = -1;//定义标准
for(int i = 0; i < len; i++)//遍历字符串
{
if(s[i] == '(')//入栈
{
str[++top] = i;
}
if(s[i] == ')')//出栈
{
--top;
if(top == -1)//重新定义标准
{
str[++top] = i;
}
else
{
max = MAX(max , (i - str[top]));
}
}
}
return max;
}
作者:xun-ge-v
链接:https://leetcode.cn/problems/longest-valid-parentheses/solution/by-xun-ge-v-h2qz/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
//动态规划
#define MAX(a , b) ((a) > (b) ? (a) : (b))
int longestValidParentheses(char * s){
int len = strlen(s);
if(len == 0)
return 0;
int dp[len];
memset(dp, 0, sizeof(int) * len);//初始化dp数组
int max = 0;
for(int i = 1; i < len; i++)//遍历字符串
{
if(s[i] == ')')//当s【i】 -> ')'分析
{
if(s[i - 1] == '(')
{
if(i-2 >= 0)
{
dp[i] = dp[i-2] + 2;
}
else
{
dp[i] = 2;
}
}
else if(i - dp[i-1] > 0 && s[i - dp[i-1] - 1] == '(')
{
if(i - dp[i-1] - 2 >= 0)
{
dp[i] = dp[i-dp[i-1] - 2] + dp[i - 1] + 2;
}
else
{
dp[i] = dp[i - 1] + 2;
}
}
}
max = MAX(max , dp[i]);
}
return max;
}
作者:xun-ge-v
链接:https://leetcode.cn/problems/longest-valid-parentheses/solution/by-xun-ge-v-h2qz/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
时间空间复杂度
边栏推荐
- Jmeter实战 | 同用户重复并发多次抢红包
- 4.1 配置Mysql与注册登录模块
- 织梦通过数据库查询调用当前文章的留言
- What is the difference between a utility model patent and an invention patent?Understand in seconds!
- 淘宝获取收货地址列表的 API
- iptables的使用简单测试
- MySQL Syntax Basics
- Interview assault 70: what is the glue bag and a bag?How to solve?
- 用户身份标识与账号体系实践
- Excel advanced drawing techniques, 100 (22) - how to respectively the irregular data
猜你喜欢
随机推荐
Fork/Join线程池
Questions I don't know in database kernel interview(1)
Goroutine Leaks - The Forgotten Sender
【Kaggle】House Prices
What is the difference between a utility model patent and an invention patent?Understand in seconds!
STAHL触摸屏维修一体机显示屏ET-316-TX-TFT常见故障
Pytorch框架学习记录9——非线性激活
15 分钟带你入门 Grafana
AQS原理和介绍
使用员工管理软件,解锁人力生产力新水平,提高人力资源团队灵活性
360借条安全专家:陌生微信好友不要轻易加贷款推广多是诈骗
技能大赛训练:A部分加固题目
tiup mirror merge
tiup mirror init
通过这两个 hook 回顾 Set/Map 基础知识
案例:MySQL主从复制与读写分离
列表页常见的 hook 封装
WeChat applet cloud development | personal blog applet
附录A printf、varargs与stdarg A.1 printf函数族
Excel advanced drawing techniques, 100 (22) - how to respectively the irregular data









