Leetcode之深度优先搜索(DFS)专题-301. 删除无效的括号(Remove Invalid Parentheses)
Leetcode之深度优先搜索(DFS)专题-301. 删除无效的括号(Remove Invalid Parentheses)
删除最小数量的无效括号,使得输入的字符串有效,返回所有可能的结果。
说明: 输入可能包含了除 (
和 )
以外的字符。
示例 1:
输入: "()())()" 输出: ["()()()", "(())()"]
示例 2:
输入: "(a)())()" 输出: ["(a)()()", "(a())()"]
示例 3:
输入: ")(" 输出: [""]
分析:需要以下三个步骤:
1、判断需要删除的括号的个数
2、删除到错误个数为0
3、再次判断序列是否合法,加入
AC代码:
class Solution { public List<String> removeInvalidParentheses(String s) { //统计需要删除多少个左右括号 int l = 0, r = 0; for (int i = 0; i < s.length(); i++) { if (s.charAt(i) == '(') l++; else if (s.charAt(i) == ')') { if (l > 0) l--;//此时有左括号可以和右括号匹配 else r++;//此时右括号落单 } } List<String> res = new ArrayList<>(); dfs(s, 0, l, r, res); return res; } private void dfs(String s, int start, int l, int r, List<String> res) { //递归终止条件,没有要删除的左括号和右括号 //此时要判断字符串是否合法,合法的话就加入结果中 if (l == 0 && r == 0) { if (isValid(s)) res.add(s); return; } for (int i = start; i < s.length(); i++) { if (i != start && s.charAt(i) == s.charAt(i - 1)) continue;//连续多个相同的括号只删除第一个 if (s.charAt(i) == '(' || s.charAt(i) == ')') { String cur = s; cur = cur.substring(0,i) + cur.substring(i+1); if (r > 0 && s.charAt(i) == ')') dfs(cur, i, l, r - 1, res); else if (l > 0 && s.charAt(i) == '(') dfs(cur, i, l - 1, r, res); } } } private boolean isValid(String s) { int count = 0; char[] chars = s.toCharArray(); for (char ch : chars) { if (ch == '(') count++; if (ch == ')') count--; if (count < 0) return false; } return count == 0; } }
作者:秦羽纶
本文版权归作者所有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文链接,否则保留追究法律责任的权利.