59、回溯-括号生成

思路: 

括号是成对出现,首先左括号可以放n个,右括号也可以放n个。如果当前左括号放了3了,右括号放了4个,错了,如果左括号放了5个,右括号放了4个。可以,继续放右括号即可。所以可以设计:

1、当前左括号-右括号>0?大于可以放右括号

2、当前左括号还剩下多少个可以放 >0 可以继续放左括号

代码如下:

 public List<String> generateParenthesis(int n) {
        List<String> ans=new ArrayList<>();
        if (n<1){
            return ans;
        }
        char[] path = new char[n * 2];
        process(0,0, n,path,ans);
        return ans;
    }

    /**
     * 
     * @param index 下标
     * @param leftNum 左括号-右括号还剩下几个
     * @param leftNumAll 左边一共可以放几个
     * @param path
     * @param ans
     */
    private void process(int index, int leftNum, int leftNumAll, char[] path, List<String> ans) {
        if (index==path.length){
            ans.add(String.valueOf(path));
        }else {
            if (leftNum>0){
                path[index]=')';
                process02(index+1,leftNum-1,leftNumAll,path,ans);
            }
            if (leftNumAll>0){
                path[index]='(';
                process02(index+1,leftNum+1,leftNumAll-1,path,ans);
            }
        }
    }

相关推荐

  1. 回溯-dfs-力扣,括号生成

    2024-05-02 14:44:03       39 阅读
  2. leetcode热题HOT 22. 括号生成(回溯)

    2024-05-02 14:44:03       38 阅读
  3. LeetCode 22 括号生成

    2024-05-02 14:44:03       66 阅读
  4. [leetcode] 22. 括号生成

    2024-05-02 14:44:03       64 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-05-02 14:44:03       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-05-02 14:44:03       101 阅读
  3. 在Django里面运行非项目文件

    2024-05-02 14:44:03       82 阅读
  4. Python语言-面向对象

    2024-05-02 14:44:03       91 阅读

热门阅读

  1. 详解podman

    2024-05-02 14:44:03       30 阅读
  2. 004 springCloudAlibaba Gateway

    2024-05-02 14:44:03       25 阅读
  3. apache DbUtils 组件核心原理与应用

    2024-05-02 14:44:03       31 阅读
  4. Qt | QLabel 类(标签)

    2024-05-02 14:44:03       30 阅读
  5. 【Qt问题】Qt Creator 如何链接第三方库

    2024-05-02 14:44:03       35 阅读
  6. 编程一定要学好汉语,英语是次要的

    2024-05-02 14:44:03       32 阅读
  7. Linux驱动开发——(八)Linux异步通知

    2024-05-02 14:44:03       42 阅读
  8. 购物网站-批发

    2024-05-02 14:44:03       30 阅读
  9. Rust入门

    2024-05-02 14:44:03       31 阅读
  10. STM32 单片机 GPIO 的八种工作模式是什么?

    2024-05-02 14:44:03       31 阅读