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);
            }
        }
    }
相关推荐
xiaoye3708几秒前
java接口文档工具 swagger2和swagger3对比
java·服务器·前端
三维频道2 分钟前
工业级三维扫描实测:汽车灯具复杂结构件的全尺寸 3D 测量方案分析
java·人工智能·python·数码相机·3d·汽车·汽车轻量化制造
tongyiixiaohuang3 分钟前
基于轻易云的数据集成,实现企业系统间灵活对接
java·前端·数据库
猿长大人6 分钟前
算法 | 轮廓提取随笔 —— 关于像素、阈值和直觉的碎碎念
图像处理·算法
码农飞哥8 分钟前
从Java后端到AI应用开发,我这两年做了什么
java·开发语言·人工智能
啦啦啦_999912 分钟前
1. 线性回归之 向量&矩阵
算法·矩阵·线性回归
森林猿13 分钟前
IDEA-控制台乱码
java·ide·intellij-idea
A-Jie-Y14 分钟前
JAVA设计模式-工厂方法模式
java·设计模式
千云20 分钟前
问题排查报告:一次因元空间溢出导致的CPU飙升与接口超时
java·后端
DolphinDB智臾科技20 分钟前
DolphinDB 走进东南大学 | 新型电力系统高频数据处理与算法落地实战
算法