首页 > 编程语言 > 详细

[LeetCode] 22. Generate Parentheses Java

时间:2017-06-04 12:22:54      阅读:280      评论:0      收藏:0      [点我收藏+]

题目:

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,所以我们可以得出回溯点。下面的代码我是用递归求解的,也可以用非递归求。首先用一个char类型的数组保存当前得到的值,然后每次对char[]进行判断,符合条件就进行下一个位置的求解,直到最后一个位置(i=2*n-1).

代码:

 

public class Solution {
    public List<String> generateParenthesis(int n) {
        
        List<String> resList = new ArrayList<>();
        char[] possible=new char[2*n];
        traceBack(resList,possible,0, 2*n);
		return resList;
    }
	
	public void traceBack(List<String> resList,char[] possible,int t,int m){	//这里的m=2*n
		char[] x={‘(‘,‘)‘};
		if(t>=m){		//有解,输出结果
			String string=String.valueOf(possible);
			resList.add(string);
		}else{
			for(int i=0;i<=1;i++){
				int left=0,right=0;
				possible[t]= x[i];
				for(int j=0;j<=t;j++){
					if(possible[j]==‘)‘){
						right++;
					}else
						left++;
				}
				//边界条件为(的数目大于等于)数,且left<=n
				if(left>=right&&left<=m/2){	//继续下一维度的计算
					traceBack(resList,possible,t+1, m);
				}
			}
		}
		return;	
	}
}

 

  

 

[LeetCode] 22. Generate Parentheses Java

原文:http://www.cnblogs.com/271934Liao/p/6939834.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!