博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Generate Parentheses
阅读量:6504 次
发布时间:2019-06-24

本文共 1402 字,大约阅读时间需要 4 分钟。

Generate Parentheses

给定一个数字n,生成符合要求的n对括号

Given n pairs of parentheses, write a function to generate all combinations of well-formed parentheses.

For example, given n = 3, a solution set is:

"((()))", "(()())", "(())()", "()(())", "()()()"

 

1 package com.rust.TestString; 2  3 import java.util.ArrayList; 4 import java.util.List; 5  6 class solution { 7     List
res = new ArrayList
(); 8 public List
generateParenthesis(int n) { 9 if (n == 0) {10 res.add("");11 return res;12 }13 addBrackets("", 0, 0, n);//这个递归并没有返回的条件,跑到完为止14 return res;15 }16 public void addBrackets(String str,int leftB,int rightB,int n) {17 if (leftB == n && rightB == n) {18 res.add(str);19 }// 每次递归进来,根据现有情况,还会分割成不同的情况20 if (leftB < n) {21 addBrackets(str + "(", leftB + 1, rightB, n);22 } 23 if (rightB < leftB) {24 addBrackets(str + ")", leftB, rightB + 1, n);25 }26 }27 }28 public class GenerateParentheses {29 public static void main(String args[]){30 solution output = new solution();31 List
out = output.generateParenthesis(3);32 System.out.println(out.size());33 for (int i = 0; i < out.size(); i++) {34 System.out.println(out.get(i));35 }36 }37 }

 

转载地址:http://cvqyo.baihongyu.com/

你可能感兴趣的文章
25 个 Linux 性能监控工具
查看>>
C#程序员整理的Unity 3D笔记(十三):Unity 3D基于组件的思想
查看>>
Tengine-2.1.1 ngx_http_concat_module 400问题
查看>>
Windows中挂载安装ISO文件
查看>>
Wayland 1.0发布
查看>>
golang的goroutine是如何实现的?
查看>>
乐视云基于Kubernetes的PaaS平台建设
查看>>
R 学习笔记《十》 R语言初学者指南--图形工具
查看>>
PHP通过读取DOM抓取信息
查看>>
DICOM医学图像处理:DICOM网络传输
查看>>
nio和传统Io的区别
查看>>
移动端网页布局中需要注意事项以及解决方法总结
查看>>
(原创)Linux下查看系统版本号信息的方法
查看>>
oracle
查看>>
我也要谈谈大型网站架构之系列(2)——纵观历史演变(下)
查看>>
大话设计模式(Golang) 二、策略模式
查看>>
使用PostgreSQL 9.6 架设mediawiki服务器
查看>>
数据库服务器硬件对性能的影响
查看>>
LVM
查看>>
php 几个比较实用的函数
查看>>