`
haifengyulu
  • 浏览: 15453 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
最近访客 更多访客>>
社区版块
存档分类
最新评论

Leetcode Generate Parentheses

阅读更多

题目:http://oj.leetcode.com/problems/generate-parentheses/

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:

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

加括号总数本质上就是一个卡特兰数,因此我的解法跟卡特兰递推式的计算过程一样,因此,要得到n对括号的排列,得先得到1~n-1对括号的排列(当然如果需多次调用该方法以得到多个加括号方式的话,可以保存之前计算得到的值,避免重复计算),具体代码如下:

import java.util.ArrayList;

public class GenerateParentheses {
	ArrayList<ArrayList<String>> list;

	private void genParenthesis(int n, int st, int ed, StringBuilder sb,
			ArrayList<String> innerList) {
		if (st == ed) {
			innerList.add(sb.toString());
		} else {
			if (ed == 2 * n)
				sb.append(")");
			int len = (ed - st - 1) / 2;
			if (len == 0) {
				genParenthesis(n, ed, 2 * n, sb, innerList);
			} else {
				for (int k = 0; k < list.get(len).size(); k++) {
					sb.append(list.get(len).get(k));
					genParenthesis(n, ed, 2 * n, sb, innerList);
					sb.delete(sb.length() - list.get(len).get(k).length(),
							sb.length());
				}
			}
			if (ed == 2 * n) {
				sb.deleteCharAt(sb.length() - 1);
			}
		}
	}

	public ArrayList<String> generateParenthesis(int n) {
		list = new ArrayList<ArrayList<String>>();
		ArrayList<String> innerList = new ArrayList<String>();
		list.add(innerList);
		innerList = new ArrayList<String>();
		innerList.add("()");
		list.add(innerList);
		if (n <= 1)
			return list.get(n);
		StringBuilder sb = new StringBuilder();
		sb.append("(");
		for (int i = 2; i <= n; i++) {
			innerList = new ArrayList<String>();
			for (int j = 1; j < 2 * i; j += 2) {
				genParenthesis(i, 0, j, sb, innerList);
			}
			list.add(innerList);
		}
		System.out.println("Size: " + list.get(n).size() + "\n" + list.get(n));
		return list.get(n);
	}

	public static void main(String[] args) {
		GenerateParentheses gp= new GenerateParentheses();
		gp.generateParenthesis(4);
	}
}

 

分享到:
评论

相关推荐

    java-leetcode题解之Generate Parentheses.java

    java java_leetcode题解之Generate Parentheses.java

    java-leetcode题解之22-Generate-Parentheses

    java入门 java_leetcode题解之22_Generate_Parentheses

    js-leetcode题解之22-generate-parentheses.js

    js js_leetcode题解之22-generate-parentheses.js

    C语言-leetcode题解之22-generate-parentheses.c

    c语言入门 C语言_leetcode题解之22-generate-parentheses.c

    程序员面试宝典LeetCode刷题手册

    第四章 Leetcode 题解 1. Two Sum 2. Add Two Numbers 3. Longest Substring Without ...22. Generate Parentheses 23. Merge k Sorted Lists 24. Swap Nodes in Pairs 25. Reverse Nodes in k-Group 26. Remove Dupli

    LeetCode 刷题汇总1

    * 生成括号(Generate Parentheses):生成所有可能的括号组合。 6. 字符串匹配: * 正则表达式匹配(Regular Expression Matching):实现正则表达式匹配。 * 实现strStr()(Implement strStr()):实现字符串...

    leetcode信封-LeetCode:LeetCode解题

    Parentheses | ImplementstrStr.java //28. Implement strStr() │ LongestIncreasingSubsequence.java 300.Longest Increasing Subsequence | LongestPalindromicSubstring.java 5. Longest Palindromic Substring...

    lrucacheleetcode-leetcode:leetcode

    lru缓存leetcode leetcode 1. Two Sum 2. Add Two ...Generate Parentheses 25. Reverse Nodes in k-Group 26. Remove Duplicates from Sorted Array 27. Remove Element 28. Implement strStr() 3

    _leetcode-python.pdf

    - Generate Parentheses: 生成所有可能的有效的括号组合。 - Merge k Sorted Lists: 合并k个排序链表。 - Swap Nodes in Pairs / Reverse Nodes in k-Group: 这两个问题涉及到在链表中按特定规则交换节点或反转节点...

    leetcode530-algorithm:算法

    leetcode 530 ** LeetCode 题目更新 ** 用来记录业余时间所做的算法题目,保持对于数据结构的熟悉。 ** Leetcode 题目列表 ...Parentheses ...Generate Parentheses 028 Implement strStr() 031 Next Permutat

    c++-c++编程基础之leetcode题解第22题括号生成.zip

    第22题,"括号生成"(Generate Parentheses),是其中一道经典的动态规划问题,旨在考察程序员对递归、回溯以及组合的理解。这道题目要求我们生成所有有效的括号组合,即所有符合括号开闭规则的字符串。 题目描述:...

    leetcode中国-LeetCodeAnswerCollections:LeetCode题解精选代码收集

    generate-parentheses【】【中等】 这是一道递归题目,想法很重要,保证括号合法性是另一个要点 private List result; public List generateParenthesis(int n) { result = new ArrayList(); _generate(0, 0, n, "")...

    leetcode2-Algorithms-Practice:创建此repo是为了跟踪我在解决问题方面的进展

    leetcode 2 LeetCode-练习 我的 ...Generate Parentheses 运行时间:164 毫秒内存使用:22.5 MB 26. Remove Duplicates from Sorted Array 运行时间:100 毫秒内存使用:15.2 MB 27. Remove Element

    leetcode答案-LeetCode:不要放弃

    leetcode 答案LeetCode 算法的复杂度分析。...因为是递回求解,所以很抽象不好懂,这里以leetcode的generate-parentheses一道题目为例,给定n,要找出n个括号的各种组合,例如n=2 ,答案会是[(()), ()()]

    Coding Interview In Java

    237 Generate Parentheses 575 238 Combination Sum 577 239 Combination Sum II 579 240 Combination Sum III 581 241 Combinations 583 242 Letter Combinations of a Phone Number 587 243 Restore IP Addresses ...

    leetcode添加元素使和等于-programmer_practices:算法实践

    Generate Parentheses 18 3 sum 扩展版, 外层多套一个循环即可。注意判断重复及细节优化 19 细节:nodelist前插入一个dummy node. 删除倒数第n 等于正数查到len - n 20 用stack 最后stack应该是空的 21 遍历直到二...

    LeetCode 括号生成

    题目来源:https://leetcode-cn.com/problems/generate-parentheses/submissions/ 题目 给出 n 代表生成括号的对数,请你写出一个函数,使其能够生成所有可能的并且有效的括号组合。 例如,给出 n = 3,生成结果为...

    LeetCode

    题目0022:"生成括号"(Generate Parentheses) 这是一个关于回溯算法和组合问题的题目。目标是生成所有有效的括号组合,这些括号字符串必须符合正确的左右括号匹配规则。通过递归或者动态规划的策略,我们可以构建...

Global site tag (gtag.js) - Google Analytics