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

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

简单题。DFS。还是用Java写函数麻烦了。一开始把left<n的条件忘了。

import java.util.ArrayList;public class Solution {    public ArrayList
generateParenthesis(int n) { // Start typing your Java solution below // DO NOT write main() function ArrayList
arr = new ArrayList
(); ArrayList
chars = new ArrayList
(); dfs(arr, 0, 0, chars, n); return arr; } private void dfs(ArrayList
arr, int left, int right, ArrayList
chars, int n) { if (left + right + 1 == n * 2) { if (left < right) { // chars.add('(') - impossible // chars.remove(chars.size() - 1); } else { chars.add(')'); StringBuilder sb = new StringBuilder(); for (char c : chars) { sb.append(c); } arr.add(sb.toString()); chars.remove(chars.size() - 1); } } else { if (left > right) { chars.add(')'); dfs(arr, left, right + 1, chars, n); chars.remove(chars.size() - 1); } if (left < n) { chars.add('('); dfs(arr, left + 1, right, chars, n); chars.remove(chars.size() - 1); } } }}

  

转载于:https://www.cnblogs.com/lautsie/p/3224105.html

你可能感兴趣的文章
03 线程池
查看>>
201771010125王瑜《面向对象程序设计(Java)》第十三周学习总结
查看>>
java中内部类的讲解
查看>>
手机验证码执行流程
查看>>
python 基础 ----- 变量
查看>>
设计模式课程 设计模式精讲 2-2 UML类图讲解
查看>>
Silverlight 的菜单控件。(不是 Toolkit的)
查看>>
:hover 鼠标同时触发两个元素变化
查看>>
go语言学习十三 - 相等性
查看>>
Idea 提交代码到码云(提交到github也大同小异)
查看>>
c#连接excel2007未安装ISAM解决
查看>>
Mono 异步加载数据更新主线程
查看>>
初识lua
查看>>
我是插件狂人,jDuang,jValidator,jModal,jGallery
查看>>
张季跃 201771010139《面向对象程序设计(java)》第四周学习总结
查看>>
如何解除循环引用
查看>>
android中fragment的使用及与activity之间的通信
查看>>
字典【Tire 模板】
查看>>
jquery的contains方法
查看>>
python3--算法基础:二分查找/折半查找
查看>>