最长有效括号

给定一个只包含 '(' 和 ')' 的字符串,目标是找到最长的有效括号子串。例如,输入 '(()' 输出 2,输入 ')()())' 输出 4。本文介绍了通过动态规划解决该问题的思路,包括有效括号的标志数组和获取最长连续1的长度的方法。虽然解法未达到最优,但提供了学习和改进的基础。
摘要由CSDN通过智能技术生成

题目描述:

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

示例 1:

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

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

 

解题思路:

事先声明不是最优解,最后超时了,但是还是发一下目前的思路,为之后学习和思考最优解做个铺垫哈。

1)题目最长有效括号字串 ->  需要获取所有有效的括号,并且找到最长的字串

2)有效括号可以使用递归的算法进行运算,设立数组作为有效括号的标志数组,如果可以形成括号,标记1, 如果不能形成括号,标记0,最后得到最长的连续1的长度

3) 动态规划得到有效括号

    a. 如果s[i]为(,标记Flag[i]=0

    b.如果s[i]为), 获取0~i-1位s字符的标记数组,倒叙遍历,如果前面有Flag[k]=0且s[k]=(的情况,标记Flag[k]和Flag[i]为1

 

代码实现:

动态规划获得标记数组可以使用如下代码:

public static Integer[] longestValidParentheses(String s, Integer[] integers) {
        char[] chars = s.toCharArray();
  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值