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 分钟前
WIN10任务栏日期隐藏年显示星期几
windows
EntyIU2 分钟前
大文件分片上传完整案例
java
SilentSamsara3 分钟前
模型可解释性业务化:SHAP/LIME 的业务汇报与合规审查
人工智能·算法·机器学习·自动化
kuro-shiro8 分钟前
SpringBoot 启动流程
java·spring boot·后端
吴声子夜歌9 分钟前
SQL进阶——EXISTS谓词
java·数据库·sql
byte轻骑兵9 分钟前
【LE Audio】CSIP精讲[5]: 蓝牙协同设备组的安全防护体系与实战规范
算法·安全·音频·le audio·低功耗音频
偏爱自由 !11 分钟前
8. 泛型程序设计
java·开发语言·windows
剑挑星河月11 分钟前
35.搜索插入位置
java·数据结构·算法·leetcode
海兰12 分钟前
【SpringBoot 】AOP企业级权限控制方案(二)
android·java·spring boot
偏爱自由 !12 分钟前
2:IDEA中git的使用--基础操作
java·git·intellij-idea