回溯----5.括号生成

题目链接

/**

合法括号生成规则:

第一个括号必须是左括号(第一个为右必定无法闭合)

选择过程中左括号数量必须小于n才可选择左括号(大于n则一定有括号无法闭合)

左括号数量必须大于右括号数量才可选择右括号(相等代表所有前驱括号都已闭合)

所需参数:

left 记录已选择左括号数

right 记录已选择右括号数

限制条件:

由于括号必定从左括号开始的特性,左括号优先级高于右括号

left < n --> 避免左括号超量,导致无足够右括号与之闭合

left > right --> 括号未全部闭合,可选择右括号与之闭合

两条件共同保证括号生成合法性

*/

java 复制代码
class Solution {
    //保存结果集
    private List<String> res = new ArrayList<>();
    //保存单次结果
    private StringBuilder tempResult = new StringBuilder();

    private int n;

    public List<String> generateParenthesis(int n) {
        /**
            合法括号生成规则:
                            第一个括号必须是左括号(第一个为右必定无法闭合)
                            选择过程中左括号数量必须小于n才可选择左括号(大于n则一定有括号无法闭合)
                            左括号数量必须大于右括号数量才可选择右括号(相等代表所有前驱括号都已闭合)
            所需参数:
                            left 记录已选择左括号数
                            right 记录已选择右括号数
            限制条件:
                            由于括号必定从左括号开始的特性,左括号优先级高于右括号
                            left < n --> 避免左括号超量,导致无足够右括号与之闭合
                            left > right --> 括号未全部闭合,可选择右括号与之闭合
                            两条件共同保证括号生成合法性              
        */

        this.n = n;
        backtrack(0,0);

        return res;

    }

    private void backtrack(int left, int right) {
        //生成完毕,保存结果
        if(left + right == 2*n) {
            res.add(tempResult.toString());
            return;
        }

        //左括号未到上限可选择左括号
        if(left < n) { 
            tempResult.append("(");
            left++;
            backtrack(left,right);

            //回溯
            left--;
            tempResult.deleteCharAt(tempResult.length() - 1);
        }

        //左括号未全部与右括号匹配,可选择右括号
        if(left > right) {
            tempResult.append(")");
            right++;
            backtrack(left,right);

            //回溯
            right--;
            tempResult.deleteCharAt(tempResult.length() - 1);
        }
    }
}
相关推荐
朦胧之5 小时前
AI 编程-老项目改造篇
java·前端·后端
程序猿大帅9 小时前
别再只当调包侠了:用 Spring AI 落地 Function Calling,我被大模型硬生生砸出了三个大坑
java
程序员晓琪10 小时前
约定大于配置:基于 Java 包名自动生成 API 版本路由的最佳实践
java·spring boot·后端
Flittly10 小时前
【AgentScope Java新手村系列】(11)中断与恢复
java·spring boot·spring
众少成多积小致巨11 小时前
JNI (Java Native Interface) 技术手册中文参考指南
android·java·c++
东坡白菜11 小时前
破局全栈:前端开发的Java入门实战记录—JPA(2)
java·后端
SimonKing17 小时前
艹,维护AI写的代码,我心态崩了......
java·后端·程序员
用户2986985301418 小时前
Java Word 文档样式进阶:段落与文本背景色设置完全指南
java·后端
小bo波1 天前
从"任意文件复制"深挖Java I/O:字符流与字节流的本质抉择
java·nio·io流·后端开发·文件复制
nanxun8862 天前
记一次诡异的 Docker 容器"串包"故障排查
java