博客
关于我
LeetCode-32.最长有效括号
阅读量:801 次
发布时间:2023-01-31

本文共 967 字,大约阅读时间需要 3 分钟。

给定一个只包含 '(' 和 ')' 的字符串,找出最长的包含有效括号的子串的长度。

示例 1:

输入: "(()"输出: 2解释: 最长有效括号子串为 "()"

示例 2:

输入: ")()())"输出: 4解释: 最长有效括号子串为 "()()"
1 /* 2     采用动态规划建立一个与给定字符串长度相等的数组dp,用于记录当前的有效括号长度 3     1.从下标为1的开始遍历,若当前下标为i的字符为'('时,则跳过(默认置为0) 4     2.若当前下标为i的字符为')’时,获取dp[]中前一个字符的数值,即dp[i-1],并获取指向的前dp[i-1]个字符下标(跳过有效括号字串,寻找前面未匹配的括号) 5     3.若有效括号字串的前一个字符为'(',即匹配成功,当前dp[i]获得前一个的数值加二(即dp[i]=dp[i-1]+2,2分别为()括号) 6     4.判断是否连续的有效括号:获得刚匹配成功的前一个dp数值,查看是否为0(即dp[i-2-dp[i-1]]),若不为0,则相当于连续字串,最后再加上dp[i-2-dp[i-1]]. 7 */ 8 class Solution { 9     public int longestValidParentheses(String s) {10         int len=s.length();11         int max=0;12         int []dp=new int[len];13         for(int i=1;i
=0){26 if(dp[lastindex]!=0)27 dp[i]+=dp[lastindex];28 }29 }30 if(dp[i]>max)31 max=dp[i];32 }33 return max;34 }35 }

 

 

转载于:https://www.cnblogs.com/lyh28/p/10512554.html

你可能感兴趣的文章
Navicat连接Oracle出现Oracle library is not loaded的解决方法
查看>>
Navicat连接Oracle数据库以及Oracle library is not loaded的解决方法
查看>>
Navicat连接sqlserver提示:未发现数据源名并且未指定默认驱动程序
查看>>
navicat连接远程mysql数据库
查看>>
Navicat通过存储过程批量插入mysql数据
查看>>
Navicat(数据库可视化操作软件)安装、配置、测试
查看>>
navigationController
查看>>
NB-IOT使用LWM2M移动onenet基础通信套件对接之APN设置
查看>>
NBear简介与使用图解
查看>>
Vue过滤器_使用过滤器进行数据格式化操作---vue工作笔记0015
查看>>
Ncast盈可视 高清智能录播系统 IPSetup.php信息泄露+RCE漏洞复现(CVE-2024-0305)
查看>>
NCNN中的模型量化解决方案:源码阅读和原理解析
查看>>
NCNN源码学习(1):Mat详解
查看>>
nc命令详解
查看>>
NC综合漏洞利用工具
查看>>
ndarray 比 recarray 访问快吗?
查看>>
ndk-cmake
查看>>
NdkBootPicker 使用与安装指南
查看>>
ndk特定版本下载
查看>>
NDK编译错误expected specifier-qualifier-list before...
查看>>