当前位置: 首页 > news >正文

Longest Valid Parentheses(动态规划)

Longest Valid Parentheses

更多技术博客 http://vilins.top/

题目

Given a string containing just the characters ‘(’ and ‘)’, find the length of the longest valid (well-formed) parentheses substring.

Example 1:

Input: “(()”
Output: 2
Explanation: The longest valid parentheses substring is “()”
Example 2:

Input: “)()())”
Output: 4
Explanation: The longest valid parentheses substring is “()()”

分析

在这里我们用一个longest_curr数组去保存当前下标前连续匹配的括号的数量,注意这里是连续出现的括号。
接下来我们需要找出状态转移方程,当字符串的字符为’)‘时可能意味着状态的改变,所以我们的判断条件是在’)‘时进行的。
具体来说,在下标i之前的longest_curr值都已经被求出来了,那么对于下标为并且是’)'的字符,有如下状态转移方程:

longest_curr[i] = longest_curr[i - longest_curr[i-1] - 2] + 2 + longest_curr[i-1];

longest_curr[i - longest_curr[i-1] - 2]是指在这个整体匹配之前已经匹配的字符数量,
longest_curr[i-1]指存在这样的情况“()(())",longest_curr[i-1]指计算(()),这个符合中间的这两个。
最后需要考虑的一点就是下标的界限问题。

源码

class Solution { public: int longestValidParentheses(string s) { int size = s.size(); int max_num = 0; vector<int> longest_curr(size, 0); if(s.size() <= 1) { return 0; } for(int i =1; i < size; i++) { if(s[i] == ')' && ((i - longest_curr[i-1] - 1) >= 0) && s[i - longest_curr[i-1] - 1] == '(') { if(i - longest_curr[i-1] - 2 >= 0) { longest_curr[i] = longest_curr[i - longest_curr[i-1] - 2] + 2 + longest_curr[i-1]; } else { longest_curr[i] = 2 + longest_curr[i-1]; } max_num = max(max_num, longest_curr[i]); } } return max_num; } };

更多技术博客 http://vilins.top/

http://www.rkmt.cn/news/1444658.html

相关文章:

  • 2026年亲测AI论文写作软件榜单(安全合规版)
  • Sora 2配音与Premiere Pro/FCPX/Davinci Resolve无缝协同指南,附官方未文档化的Timecode Injection协议
  • 2026年近期想找温州老爹鞋直销厂商?这五家实力供应商值得关注 - 2026年企业资讯
  • CentOS 7上DM8开发版安装避坑实录:从dmdba用户创建到服务注册的完整踩坑指南
  • Spring Boot 3 + Swagger 3 + Knife4j 4.1.0:从配置到美化,打造团队都爱用的API文档(避坑指南)
  • 如何免费永久保存微信聊天记录:WeChatMsg终极完整使用指南
  • 格式规范否?8款AI论文写作工具梯队榜,毕业答辩稳了!
  • 【Sora 2倒放视频生成黑科技】:全球仅3家实验室验证的时序逆向建模方法首度公开
  • 保姆级教程:用Python和Pandas快速上手UJIIndoorLoc室内定位数据集
  • Edit Distance(动态规划)
  • 告别VCP!用FTDI D2XX库直接驱动MPSSE引擎(以FT2232H为例,含C++/Qt代码)
  • 电玩城游戏机实测评测:电玩城游戏机、文审游戏机、出票游戏机、商用游戏机、实物五门文审机、扣篮王游戏机、扣篮王选择指南 - 优质品牌商家
  • 别再只跑默认参数了!TransDecoder 5.7.1高级参数调优与结果深度解读指南
  • 告别虚拟机!在Win10上为GAMMA搭建MSYS2+WinPython轻量级开发环境实录
  • 上海原配追讨财产律师权威排行:上海老公给小三转的钱怎么要回、上海虹口婚外情维权律师、上海起诉小三流程和费用、上海起诉小三返还财产律师选择指南 - 优质品牌商家
  • 别再乱用通配符了!SpringBoot3中PathPattern的匹配规则详解与性能测试
  • 算法设计与分析--动态规划(十)
  • 2026年镍焊膏可靠性评测:黄铜焊膏/助焊膏/定制焊料/异形环/活性钎料/焊带/焊接加工/焊片/焊环/粘带焊料/选择指南 - 优质品牌商家
  • 2026年西门子S71200模块主流供应商排行盘点:光伏储能集成机柜/定制PLC控制柜/恒压供水控制柜/成套电气控制柜/选择指南 - 优质品牌商家
  • 从Arduino到KSP实体控制台:硬件架构、通信协议与工程实践全解析
  • 2026年靠谱的温州地蹦床/户外蹦床/多人蹦床/温州弹跳蹦床公司选择指南 - 品牌宣传支持者
  • 别再只用欧氏距离了!用Python+NumPy手把手实现豪斯多夫距离,搞定图像匹配与异常检测
  • 2026年建筑工程主体结构检测机构第三方实测评测:广告牌性能检测、建筑工程主体结构检测、户外显示屏支架质量检测选择指南 - 优质品牌商家
  • 别再只玩Arduino了!用ESP8266-12F做个智能插座,从硬件选型到MQTT接入保姆级教程
  • 告别过曝和死黑!用Python+OpenCV玩转HDR多曝光融合,手机拍的照片也能救回来
  • 2026年钛合金切削液主流供应商排行及适配解析:铝合金切削液/铸铁切削液/镁合金切削液/防锈油/防锈蜡/陶瓷切削液/选择指南 - 优质品牌商家
  • 告别依赖地狱:在Ubuntu 18.04上通过Snap或Flatpak无痛安装最新版VS Code
  • 手把手教你用classification_report做多分类任务模型调优(附完整代码与可视化)
  • 基于NodeMCU与Blynk的智能花盆:物联网环境监测实践
  • EVE舰船配置终极指南:为什么你需要Python Fitting Assistant