[LeetCode]301. 删除无效的括号(DFS)
题目
题解
step1. 遍历一遍,维护left、right计数器,分别记录不合法的左括号、右括号数量.
- 判断不合法的方法?
- left维护未匹配左括号数量(增,减)(当left为0遇到右括号,则交由right处理),最终剩余的左括号数量就是不合法的左括号数量
- 遇右括号时,若左侧的左括号都已被匹配(left==0),则此右括号为不合法右括号,right++
- PS 对于题目中最少:此方法判断出的所有不合法括号,就是所谓的最少不合法括号数量;在此基础上得到的合理表达式,删除成对的括号,也会是合法表达式。
- PS 为什么不同于判断合法括号的题目,只使用一个left计数器? 因为要对不合法的左括号和右括号分别记录数量.
- 判断不合法的方法?
step2.利用dfs不断删除"("或者")",直到不合法个数为0。参照相关中的步骤:
- dfs参数有:当前删除已删除括号后的字符串,待处理位置,剩余不合法左括号数l,剩余右括号不合法数r;
- 特别判断:去重:若当前字符和之前字符相同,则continue;
- 返回条件:l0&&r0,且当前字符串括号合法。
- 删除当前括号,进入下一层搜索
step3.检验删除后的括号串是否合法。
使用left计数器判断即可。注意: 当前还有不合法左(右)括号且当前括号为左(右)括号,才能进入下一层搜索。
注意:下一层搜索的第一个参数
相关
判断括号有效:
- 法1 (单一种类括号):维护left计数器
- 法2 (多种类括号):使用栈
dfs关键:
- dfs参数
- 一些特别的剪枝条件,根据情况选择直接返回或者continue
- dfs返回条件并返回,同时可能需要记录一些需要的结果
- 进入下层搜索的条件
String:
str1.subString(beg,end); //拷贝
str2.subStr(beg,len); //拷贝
代码
class Solution {
private List<String> validStrList;
public List<String> removeInvalidParentheses(String s) {
// 得到不合法左括号数和右括号数
int lCnt = 0;
int rCnt = 0;
for (int i = 0; i < s.length(); ++i) {
if (s.charAt(i) == '(') {
lCnt++;
} else if (s.charAt(i) == ')') {
if (lCnt > 0) {
lCnt--;
} else {
rCnt++;
}
}
}
validStrList = new ArrayList<>();
dfs(s, 0, lCnt, rCnt);
return validStrList;
}
private void dfs(String s, int pos, int lCnt, int rCnt) {
if (lCnt == 0 && rCnt == 0) {
if (validStr(s)) {
validStrList.add(s);
}
return;
}
for (int i = pos; i < s.length(); ++i) {
if (i != pos && s.charAt(i) == s.charAt(i - 1)) {
continue;
}
if (lCnt > 0 && s.charAt(i) == '(') {//
dfs(s.substring(0, i) + s.substring(i + 1), i, lCnt - 1, rCnt);//
}
if (rCnt > 0 && s.charAt(i) == ')') {//
dfs(s.substring(0, i) + s.substring(i + 1), i, lCnt, rCnt - 1);//
}
}
}
private boolean validStr(String s) {
int left = 0;
for (int i = 0; i < s.length(); ++i) {
if (s.charAt(i) == '(') {
left++;
} else if (s.charAt(i) == ')') {
if (left <= 0) {
return false;
}
left--;
}
}
return left == 0;
}
}
[LeetCode]301. 删除无效的括号(DFS)的更多相关文章
- Java实现 LeetCode 301 删除无效的括号
301. 删除无效的括号 删除最小数量的无效括号,使得输入的字符串有效,返回所有可能的结果. 说明: 输入可能包含了除 ( 和 ) 以外的字符. 示例 1: 输入: "()())()&quo ...
- Leetcode 301.删除无效的括号
删除无效的括号 删除最小数量的无效括号,使得输入的字符串有效,返回所有可能的结果. 说明: 输入可能包含了除 ( 和 ) 以外的字符. 示例 1: 输入: "()())()" 输出 ...
- Leetcode之深度优先搜索(DFS)专题-301. 删除无效的括号(Remove Invalid Parentheses)
Leetcode之深度优先搜索(DFS)专题-301. 删除无效的括号(Remove Invalid Parentheses) 删除最小数量的无效括号,使得输入的字符串有效,返回所有可能的结果. 说明 ...
- 301 Remove Invalid Parentheses 删除无效的括号
删除最小数目的无效括号,使输入的字符串有效,返回所有可能的结果.注意: 输入可能包含了除 ( 和 ) 以外的元素.示例 :"()())()" -> ["()()() ...
- [Swift]LeetCode301. 删除无效的括号 | Remove Invalid Parentheses
Remove the minimum number of invalid parentheses in order to make the input string valid. Return all ...
- [LeetCode] 301. Remove Invalid Parentheses 移除非法括号
Remove the minimum number of invalid parentheses in order to make the input string valid. Return all ...
- [LeetCode] 20. Valid Parentheses 合法括号
Given a string containing just the characters '(', ')', '{', '}', '[' and ']', determine if the inpu ...
- 每日一道 LeetCode (6):有效的括号
每天 3 分钟,走上算法的逆袭之路. 前文合集 每日一道 LeetCode 前文合集 代码仓库 GitHub: https://github.com/meteor1993/LeetCode Gitee ...
- word中几个好用的宏代码(立方米上标、关闭样式自动更新、删除无效样式、表格加粗边框、宋体引号)
Sub 替换立方米() With Selection.Find .Text = "m3" .Replacement.Text = "mm3" .Forward ...
随机推荐
- 图论算法(三) 最短路SPFA算法
我可能要退役了…… 退役之前,写一篇和我一样悲惨的算法:SPFA 最短路算法(二)SPFA算法 Part 1:SPFA算法是什么 其实呢,SPFA算法只是在天朝大陆OIers的称呼,它的正统名字叫做: ...
- vue2和vue3的区别
一.常用命令 vue -V 查看本地 vue 版本 二.官方文档 3.0:https://cli.vuejs.org/zh/ 三.创建文件 3.0:vue create 进入工程文件夹,创建项目. 2 ...
- java+opencv实现人脸识别程序记录
结果 基本实现了识别的功能.基本的界面如下 界面长得比较丑,主要是JavaSwing写界面比较麻烦,写个菜单栏都要那么多代码.目前不打算改了. 实现的思路是:使用opencv中自带的OpenCVFra ...
- SEGGER studio问题
刚开始学习用SEGGER studio编译调试nordic 52840程序,在此记录遇到的问题. 1. Additional Load File[0]:"E:\nordic/nRF5_SD ...
- SpringCloudAlibaba-服务网关Gateway
一:网关简介 在微服务架构中,一个系统会被拆分为很多个微服务.那么作为客户端要如何去调用这么多的微服务呢?如果没有网关的存在,我们只能在客户端记录每个微服务的地址,然后分别去调用.这样的话会产生很多问 ...
- 记写 android 微信登录的demo历程
前言 首先看一条链接: https://github.com/Tencent/WeDemo 腾讯给了一个wedemo,微信第三方登录的例子.里面是php和ios,ios是object写的,php还是原 ...
- 2.Oracle数据库安装教程
一.准备安装 基本都是按部就班. 使用的OS版本:OEL4 安装程序路径: /mnt/Oracle11g_linux_x86_64/database 创建用户 使用的.bash_profile 修改的 ...
- springMVC入门(一)------springMVC基本概念与安装
springMVC简介 springMVC是一个基于MVC的web框架,属于SpringFrameWork的后续产品,已经融合在Spring Web Flow里面. springMVC安装 本例中使用 ...
- Spring Security认证流程分析--练气后期
写在前面 在前一篇文章中,我们介绍了如何配置spring security的自定义认证页面,以及前后端分离场景下如何获取spring security的CSRF Token.在这一篇文章中我们将来分析 ...
- latex:公式的序号
1.排序单位 在文类book或report中,行间公式是以章为排序单位的,即每一新章节开始,公式序号计数器equation就被清零.比如第1章第3个公式的序号是(1.3),第2章第1个公式的序号是(2 ...