题目

题解

  • step1. 遍历一遍,维护left、right计数器,分别记录不合法的左括号、右括号数量.

    • 判断不合法的方法?

      • left维护未匹配左括号数量(增,减)(当left为0遇到右括号,则交由right处理),最终剩余的左括号数量就是不合法的左括号数量
      • 遇右括号时,若左侧的左括号都已被匹配(left==0),则此右括号为不合法右括号,right++
      • PS 对于题目中最少:此方法判断出的所有不合法括号,就是所谓的最少不合法括号数量;在此基础上得到的合理表达式,删除成对的括号,也会是合法表达式。
      • PS 为什么不同于判断合法括号的题目,只使用一个left计数器? 因为要对不合法的左括号和右括号分别记录数量.
  • step2.利用dfs不断删除"("或者")",直到不合法个数为0。参照相关中的步骤:

    1. dfs参数有:当前删除已删除括号后的字符串,待处理位置,剩余不合法左括号数l,剩余右括号不合法数r;
    2. 特别判断:去重:若当前字符和之前字符相同,则continue;
    3. 返回条件:l0&&r0,且当前字符串括号合法
    4. 删除当前括号,进入下一层搜索
  • step3.检验删除后的括号串是否合法。

    使用left计数器判断即可。

  • 注意: 当前还有不合法左(右)括号且当前括号为左(右)括号,才能进入下一层搜索。

  • 注意:下一层搜索的第一个参数

相关

判断括号有效:

  • 法1 (单一种类括号):维护left计数器
  • 法2 (多种类括号):使用栈

dfs关键:

  1. dfs参数
  2. 一些特别的剪枝条件,根据情况选择直接返回或者continue
  3. dfs返回条件并返回,同时可能需要记录一些需要的结果
  4. 进入下层搜索的条件

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)的更多相关文章

  1. Java实现 LeetCode 301 删除无效的括号

    301. 删除无效的括号 删除最小数量的无效括号,使得输入的字符串有效,返回所有可能的结果. 说明: 输入可能包含了除 ( 和 ) 以外的字符. 示例 1: 输入: "()())()&quo ...

  2. Leetcode 301.删除无效的括号

    删除无效的括号 删除最小数量的无效括号,使得输入的字符串有效,返回所有可能的结果. 说明: 输入可能包含了除 ( 和 ) 以外的字符. 示例 1: 输入: "()())()" 输出 ...

  3. Leetcode之深度优先搜索(DFS)专题-301. 删除无效的括号(Remove Invalid Parentheses)

    Leetcode之深度优先搜索(DFS)专题-301. 删除无效的括号(Remove Invalid Parentheses) 删除最小数量的无效括号,使得输入的字符串有效,返回所有可能的结果. 说明 ...

  4. 301 Remove Invalid Parentheses 删除无效的括号

    删除最小数目的无效括号,使输入的字符串有效,返回所有可能的结果.注意: 输入可能包含了除 ( 和 ) 以外的元素.示例 :"()())()" -> ["()()() ...

  5. [Swift]LeetCode301. 删除无效的括号 | Remove Invalid Parentheses

    Remove the minimum number of invalid parentheses in order to make the input string valid. Return all ...

  6. [LeetCode] 301. Remove Invalid Parentheses 移除非法括号

    Remove the minimum number of invalid parentheses in order to make the input string valid. Return all ...

  7. [LeetCode] 20. Valid Parentheses 合法括号

    Given a string containing just the characters '(', ')', '{', '}', '[' and ']', determine if the inpu ...

  8. 每日一道 LeetCode (6):有效的括号

    每天 3 分钟,走上算法的逆袭之路. 前文合集 每日一道 LeetCode 前文合集 代码仓库 GitHub: https://github.com/meteor1993/LeetCode Gitee ...

  9. word中几个好用的宏代码(立方米上标、关闭样式自动更新、删除无效样式、表格加粗边框、宋体引号)

    Sub 替换立方米() With Selection.Find .Text = "m3" .Replacement.Text = "mm3" .Forward ...

随机推荐

  1. 《Windows程序设计(第5版 珍藏版)》配书光盘

    https://pan.baidu.com/s/1ro72qQja_xTbf-Ik8b06Ng

  2. SVN的基本使用

    2020年7月6日 为什么需要版本控制? 需要清晰地保存某些文件的不同修订版本 控制文件的发屐过程,找出导致 BUG 的原因 轻松将项目或文件恢复到指定版本 极大方便团队之间协同开发,防止出现混乱 在 ...

  3. fatal error: glib.h: No such file or directory

    在学习BLE bluez的时候,做了一个测试程序,看到gatttool.c下面有一个glib解析命令行的功能,想移植到自己的程序接口中,但是添加了#include <glib.h>后,出现 ...

  4. Jmeter 常用函数(28)- 详解 __FileToString

    如果你想查看更多 Jmeter 常用函数可以在这篇文章找找哦 https://www.cnblogs.com/poloyy/p/13291704.html 作用 读取整个文件 语法格式 ${__Fil ...

  5. 12c RAC 用Rman 恢复到异机单实例

    准备工作 原服务器软件部署:Redhat 6.6 + Oracle 12.2.0.1 rac Oracle12c单实例安装 1.创建恢复服务器,设置大于原库数据大小的磁盘容量.设置相同的服务器主机名参 ...

  6. PowerDesigner 使用笔记

    1.将mysql数据结构导入到PowerDesigner https://blog.csdn.net/guochanof/article/details/81905616 2.设计数据库过程 http ...

  7. docker run 创建容器

    docker run常用命令 docker run :创建一个新的容器并运行一个命令 - 语法:docker run [OPTIONS] IMAGE [COMMAND] [ARG...] 1.OPTI ...

  8. 简单实现C++Stack模板

    栈的特点是先进后出以及只能在栈顶进行插入和删除操作 本次实现的栈的基本操作: 1)弹栈 2)压栈 3)求栈大小 4)求栈容量 5)判断栈空 6)获取栈顶元素 1.用数组的方式实现栈基本操作 /** * ...

  9. DVWA之文件包含(一)

    文件包含又可以是本地文件包含或远程文件包含. 本地文件包含:文件存在本地目录 远程文件包含:文件共享或存在网络上,需要访问 <?php // The page we wish to displa ...

  10. spring mvc 国际化的几种方案

    spring mvc 国际化的几种方案 首先配置我们项目的service-servlet.xml文件添加的内容如下: <bean id="messageSource" cla ...