#yyds干货盘点# 面试必刷TOP101:括号生成
发布时间:2022-11-26 20:17:27 259 相关标签: # java# java# 数据
1.简述:
描述给出n对括号,请编写一个函数来生成所有的由n对括号组成的合法组合。
例如,给出n=3,解集为:
"((()))", "(()())", "(())()", "()()()", "()(())"
数据范围:
要求:空间复杂度
,时间复杂度 
示例1输入:
返回值:
示例2
输入:
返回值:
2.代码实现:
import java.util.*;
public class Solution {
public void recursion(int left, int right, String temp, ArrayList res, int n){
//左右括号都用完了,就加入结果
if(left == n && right == n){
res.add(temp);
return;
}
//使用一次左括号
if(left < n){
recursion(left + 1, right, temp + "(", res, n);
}
//使用右括号个数必须少于左括号
if(right < n && left > right){
recursion(left, right + 1, temp + ")", res, n);
}
}
public ArrayList generateParenthesis (int n) {
//记录结果
ArrayList res = new ArrayList();
//递归
recursion(0, 0, "", res, n);
return res;
}
}
文章来源: https://blog.51cto.com/u_15488507/5709990
特别声明:以上内容(图片及文字)均为互联网收集或者用户上传发布,本站仅提供信息存储服务!如有侵权或有涉及法律问题请联系我们。
举报