【LeetCode笔记】32. 最长有效括号(Java、动态规划、栈、字符串)

文章目录

  • 题目描述
  • 代码 & 解析
      • 1. 栈做法
      • 2. 动态规划

题目描述

  • (括号题真的好烦人)
  • 讲道理,题目一看,大概率就是用dp做
    在这里插入图片描述

代码 & 解析

1. 栈做法

  • 这个做法我没实际写,但是感觉很厉害,就记录一下。
  • 我们之前做括号正确判断的时候,就用到了栈来进行匹配判断。
    如今也可以用栈来进行正确判断,并记录下可行的括号的下标,
    比如(1,4)(2,3)(7,8),得到142378,而后一次排序O(nlogn),得到123478。
    在这个有序数组中找到最长连续子串即可。
    (当然,这里可以优化成O(n),排序用其他方法代替。)

2. 动态规划

  • 具体见注释
/*** 使用dp做法* 我是觉得,难点在于考虑dp数组的设计(一维、二维)* 以及dp数组存储值代表的意思* 再就是循环的设计(头到尾、尾到头、短到长)* 最后是状态转移方程的设计,这个要根据实际问题来,感觉是最难的:*   1. 有哪几种转移情况?(分类,真的不容易:要找出最合适的分类,并且要分类包括所有情况)*   2. 为什么转移,为什么可以这么转移
*/class Solution {public int longestValidParentheses(String s) {if (s == null || s.length() == 0){return 0;}int ans = 0;int len = s.length();// dp[i]代表以s.charAt[i]结尾的最长有效括号int[] dp = new int[len];// O(n)for (int i=0; i<len; i++){char ch = s.charAt(i);// 这种情况肯定是0,"xxxxxxx...(",以这玩意结尾必然无效:可以省略不写,默认为0/*if(ch == '('){dp[i] = 0;}*/// ')'有两种情况if(i > 0 && ch == ')'){// 刚好契合的情况,构成"xxxxxx()"if(s.charAt(i-1) == '(') {// 加上之前的最长有效括号dp[i] = i-2 >= 0? dp[i-2] + 2 : 2;}// "xxxxxx))"的情况else{// 用【】来代表dp[i]组成的括号:"xx【xxxxx)】"// 此时 s.charAt[i - dp[i-1]-1]可能是数组越界,或者是'('、')'int left = i - dp[i-1]-1;if(left >= 0 && s.charAt(left)=='('){dp[i] = left-1>=0?dp[i-1]+2+dp[left-1] : dp[i-1] + 2;// "x【"中延续x的长度}/* //可以省略,默认0else{dp[i] = 0;}*/}ans = Math.max(dp[i],ans);}}return ans;}        
}
  • 整理一下
class Solution {public int longestValidParentheses(String s) {if (s == null || s.length() == 0){return 0;}int ans = 0;int len = s.length();// dp[i]:以s.charAt[i]结尾的最长有效括号int[] dp = new int[len];// O(n)for (int i=0; i<len; i++){char ch = s.charAt(i);// Case 1: "xx(",以'('结尾必然无效,默认为0// Case 2: ')'有两种情况if(i > 0 && ch == ')'){// 刚好契合的情况,构成"xxxxxx()"if(s.charAt(i - 1) == '(') {// 加上之前的最长有效括号dp[i] = i - 2 >= 0 ? dp[i - 2] + 2 : 2;}// "xxxxxx))"的情况else{// 用【】来代表dp[i]组成的括号:"xx【xxxxx)】"// 此时 s.charAt[i - dp[i-1]-1]可能是数组越界,或者是'('、')'int left = i - dp[i - 1] - 1;if(left >= 0 && s.charAt(left)=='('){dp[i] = left - 1 >= 0 ? dp[i - 1] + 2 + dp[left - 1] : dp[i - 1] + 2;// "x【"中延续x的长度}// else 为默认0,省略不写}ans = Math.max(dp[i], ans);}}return ans;}        
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/504592.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

php分页类smary,Smarty分页实现方法完整实例

这篇文章主要介绍了Smarty分页实现方法,涉及基于Smarty的数据库查询、分页相关计算与模板操作技巧,需要的朋友可以参考下本文实例讲述了Smarty分页实现方法。分享给大家供大家参考&#xff0c;具体如下&#xff1a;首先是PHP文件部分&#xff1a;require("include.php&quo…

【LeetCode笔记】33. 搜索螺旋排序数组(Java、二分)

文章目录题目描述思路 & 代码题目描述 有序数组中搜索值&#xff0c;显然用二分旋转带来的影响并不大&#xff0c;只要多加几个判断&#xff0c;改改范围就行。 思路 & 代码 首先找出两部分升序子数组的分割点k然后再判断需要在哪个子数组进行二分&#xff0c;并进…

301.inc.php,DeDeCMS默认首页及WWW域的301跳转

你是否留心过&#xff1a;通过域名访问网站首页时&#xff0c;网页返回Http状态码是什么&#xff1f;甚至访问内页时&#xff0c;Http状态码又是什么吗&#xff1f;大多数人可能会想当然的认为首页返回的肯定是200&#xff0c;因为我们很容易观察到首页能否可以正常打开以及URL…

【LeetCode笔记】39. 组合总和(Java、DFS回溯、队列)

文章目录题目描述思路 & 代码题目描述 讲道理&#xff0c;像这种找可行集合解的问题&#xff0c;基本上都可以通过回溯 剪枝来做 思路 & 代码 sort()用于优化&#xff0c;多一个剪枝判断&#xff0c;其实也可以不写双向队列deque&#xff1a;第一次用&#xff0c;…

【LeetCode笔记】34. 在排序数组中查找元素的第一个和最后一个位置(Java、二分)

文章目录题目描述思路 & 代码1. 暴力法2. 二分法3. 二分法——简略版题目描述 老套路了&#xff0c;有序找元素&#xff0c;直接冲二分思路是不难想&#xff0c;就是边界条件限制条件有点恶心&#xff0c;时不时爆个栈 思路 & 代码 1. 暴力法 一次遍历找到left&am…

【LeetCode笔记】42. 接雨水(Java、动态规划)

文章目录题目描述代码 & 思路方法一&#xff1a;暴力法方法二&#xff1a;动态规划题目描述 当前列有水判断&#xff1a;左边最高列 & 右边最高列的短板不小于当前列 代码 & 思路 方法一&#xff1a;暴力法 对于每一列O(n)&#xff0c;都找出左边最高列O(n)&a…

【LeetCode笔记】46. 全排列(Java、DFS回溯、队列)

文章目录题目描述代码 & 思路题目描述 老简单了&#xff0c;一眼就是用visited数组记录出现过的数字&#xff0c;依次基础上进行回溯即可和前面的题目很像&#xff0c;用队列结合回溯使用 代码 & 思路 class Solution {public List<List<Integer>> per…

【LeetCode笔记】48. 旋转图像(Java、矩阵、偏数学、原地算法)

文章目录题目描述代码 & 思路题目描述 矩阵题&#xff0c;一眼就感觉很烦&#xff0c;直接看了题解 因为要求原地旋转&#xff0c;所以只能用temp来做当然&#xff0c;我们还是要回顾一下矩阵转置的&#xff0c;看看和这道题有啥不同&#xff0c;说不定就能用上呢。好的&a…

【LeetCode笔记】49. 字母异位词分组(Java、字符串、哈希表)

文章目录题目描述代码 & 思路题目描述 考虑&#xff1a;如何把字母相同、排列不同的字符串组合成一个相同的、独一无二的东西&#xff1f;尝试1&#xff1a;使用ascii的和&#xff08;不行&#xff0c;虽然说确实相同&#xff0c;但是独一无二不满足&#xff09;尝试2&…

【LeetCode笔记】55. 跳跃游戏(Java、贪心法)

文章目录题目描述解法 & 思路题目描述 可以用动态规划来做&#xff0c;dp[i]代表以第i个下标做起点&#xff0c;可以到达的最远的地方&#xff0c;从后往前走&#xff0c;最后dp[0] > len-1说明可达。不过我的dp相对于贪心法慢了不少(400ms&#xff09; 解法 & 思…

【LeetCode笔记】56. 合并区间(Java、排序)

文章目录题目描述代码 & 思路更新版 2.0题目描述 重叠区间&#xff1a;需要有重叠判断注意&#xff1a;题目并没有说集合间有序&#xff0c;因此要先做一个排序&#xff0c;以左下标为排序值&#xff08;否则会出错 代码 & 思路 经过排序后&#xff0c;只需要循环一…

【LeetCode笔记】62. 不同路径(Java、动态规划)

文章目录题目描述代码 & 思路更新 2.0 版本题目描述 一眼bfs&#xff0c;不过超时了。。。好&#xff0c;那么我们就用动态规划来做&#xff01; 代码 & 思路 和走迷宫差不多&#xff0c;从终点往起点走。dp[i][j]代表(i&#xff0c;j&#xff09;到终点的可行路径…

php创建windos用户,window_Win7系统创建及开启隐藏账户图文教程,  在电脑操作中有时候因为 - phpStudy...

Win7系统创建及开启隐藏账户图文教程在电脑操作中有时候因为个人需要就会在电脑上创建一个隐藏账户&#xff0c;隐藏账户就是在控制面板与开机选择中看不见的账户。它可以用输账号密码的方式进入也有着管理员权限。有了隐藏账户别人不会发现&#xff0c;即使别人设了密码也可以…

【LeetCode笔记】64. 最小路径和(Java、动态规划)

文章目录题目描述代码 & 题目描述题目描述 动态规划&#xff0c;dp[][]都可以直接用grid[][]。空间复杂度O(1) 代码 & 题目描述 dp[i[j] grid[i][j] (grid[i-1][j] grid[i][j-1])&#xff0c;注意边界判断时间复杂度O(m*n) class Solution {public int minPath…

php中文本设置随机颜色,php 产生随机整数,随机字符串,随机颜色等类用法

/*** 产生随机整数&#xff0c;随机字符串&#xff0c;随机颜色等** param* arrange (512.笔记) jb51.cc**/public static class RandomHelper{private static Random randomSeed new Random();/// /// Generates a random string with the given length/// /// Size of the s…

【LeetCode笔记】70. 爬楼梯(Java、动态规划)

文章目录题目描述代码 & 思路1. 动态规划 O(n)、O(n)2. 动态规划 O(n)、O(1)题目描述 DP 入门题了属于是 代码 & 思路 1. 动态规划 O(n)、O(n) dp[i]&#xff1a;可以到第 i 阶的方法有dp[i]种&#xff0c;所以dp[n]就是ans&#xff08;注意dp.length n1&#xf…

【LeetCode笔记】78. 子集(Java、dfs)

文章目录题目描述代码 & 思路更新2.0题目描述 不重复&#xff1a;用nowIndex即可&#xff0c;子集一定是下标有序的&#xff08;相对顺序和nums[]一样&#xff09; 代码 & 思路 轮流往下找即可注意&#xff1a;通过index来实现不重复&#xff0c;元素相对顺序一定要…

python中span函数,如何用python中BeautifulSoup提取无类名的span内文本

您可以使用递归函数迭代iddictionary-neodict-es的最外层div&#xff0c;以说明存在多个{}类为indent FyTYr的嵌套{}&#xff1a;from bs4 import BeautifulSoup as soupimport requests, bs4def has_class(d, c):return any(c in i.attrs.get(class, []) or has_class(getattr…

【LeetCode笔记】79. 单词搜索 剑指 Offer 12 矩阵中的路径(Java、dfs)

文章目录题目描述思路 & 代码更新版 2.0题目描述 一眼dfs&#xff0c;走四个方向即可 思路 & 代码 class Solution {boolean[][] visited;boolean found;public boolean exist(char[][] board, String word) {char[] wordArr word.toCharArray();int m board.len…

php保存复制粘贴的网页内容,JS实现网站内容的禁止复制和粘贴、另存为

JS实现网站内容的禁止复制和粘贴、另存为google搜索“document.οncοntextmenutrue;document.onselectstarttrue”会有更多详细文章使右键和复制失效使菜单"文件"&#xff0d;"另存为"失效”使右键和复制失效方法一在网页中加入以下代码&#xff1a;docum…