301. 删除无效的括号

 

class Solution {
public:
    bool isValid(string &s){
        int cnt=0;
        for(char c:s){
            if(c=='(')
                cnt++;
            else if(c==')')
                cnt--;
            if(cnt<0)
                return false;
        }
        return cnt==0;
        
    }
    vector<string> res;
    void dfs(string s, int start, int lremove, int rremove){
        if(lremove==0&&rremove==0){
            if(isValid(s))
                res.push_back(s);
            return ;
        }
        for(int i=start;i<s.length();i++){
            if(i>start&&s[i]==s[i-1])
                continue;
            if(lremove+rremove>s.length()-i)
                return ;
            if(lremove>0&&s[i]=='(')
                dfs(s.substr(0,i)+s.substr(i+1), i, lremove-1, rremove);
            if(rremove>0&&s[i]==')')
                dfs(s.substr(0,i)+s.substr(i+1), i, lremove, rremove-1);
        }
        
    }
    vector<string> removeInvalidParentheses(string s) {
        int lremove,rremove;
        lremove=rremove=0;

        for(char c:s){
            if(c=='(')
                lremove++;
            else if(c==')')
                if(lremove==0)
                    rremove++;
                else
                    lremove--;
        }
        
        dfs(s, 0, lremove, rremove);
        return res;

    }
};

相关推荐

  1. del删除脚本无效开关”

    2024-06-17 01:06:03       8 阅读
  2. 有效括号

    2024-06-17 01:06:03       38 阅读
  3. 20 有效括号

    2024-06-17 01:06:03       17 阅读
  4. Leetcode:有效括号

    2024-06-17 01:06:03       10 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-06-17 01:06:03       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-06-17 01:06:03       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-06-17 01:06:03       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-06-17 01:06:03       18 阅读

热门阅读

  1. 数据结构之B树的原理与业务场景

    2024-06-17 01:06:03       8 阅读
  2. Autosar实践——诊断配置(DaVinci Configuration)

    2024-06-17 01:06:03       6 阅读
  3. 2024.06.16 刷题日记

    2024-06-17 01:06:03       4 阅读
  4. linux发展历程

    2024-06-17 01:06:03       6 阅读
  5. atcoder ABC 358-B题详解

    2024-06-17 01:06:03       7 阅读
  6. Qt中的事件循环

    2024-06-17 01:06:03       6 阅读
  7. Linux各目录的作用

    2024-06-17 01:06:03       7 阅读
  8. MySQL 保姆级教程(四):过滤数据

    2024-06-17 01:06:03       6 阅读
  9. 一千题,No.0070(组合数的和)

    2024-06-17 01:06:03       7 阅读
  10. 新人学习笔记之(变量)

    2024-06-17 01:06:03       6 阅读
  11. python 如何生成原创文章

    2024-06-17 01:06:03       7 阅读