LeetCode 22:Generate Parentheses

原创 2015年11月19日 15:45:10

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,生成n对括号的所有合法排列。

#include<iostream>
#include<string>
#include<vector>
using namespace std;
//小括号串是一个递归结构,跟单链表、二叉树等递归结构一样,可以利用递归来一步一步构造字符串。
//当左括号出现次数小于n时,就可以放置新的左括号;
//当右括号出现次数小于左括号出现次数时,就可以放置新的右括号。
class Solution{
public:
	vector<string> generateParenthesis(int n){
		vector<string> result;
		if (n > 0)  generate(n, "", 0, 0, result);
		return result;
	}

	//其中p表示左括号‘(’的个数,q表示右括号‘)’的个数
	void generate(int n, string s, int p, int q, vector<string> &result){
		if (p == n)  //当左括号 '(' 已经有n个时,直接补上(n-q)个右括号就行
		{
			result.push_back(s.append(n - q, ')'));
			return;
		}

		generate(n, s + '(', p + 1, q, result); //当左括号还未达到n个时,添加左括号,递归处理
		if (p > q)   generate(n, s + ')', p, q + 1, result); //当左括号比右括号个数多时,可以添加右括号,递归处理
	}

};



版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

LeetCode 题解(Week15):22. Generate Parentheses

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

LeetCode 22. Generate Parentheses 解题报告

LeetCode 22. Generate Parentheses 解题报告

《LeetBook》LeetCode题解(22): Generate Parentheses[M]

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

【LeetCode】22. Generate Parentheses

【LeetCode】22. Generate Parentheses

Generate Parentheses - LeetCode 22

题目描述: Given n pairs of parentheses, write a function to generate all combinations of well-formed pa...
  • bu_min
  • bu_min
  • 2015年05月23日 20:32
  • 239

<LeetCode OJ> 22. Generate Parentheses

22. Generate Parentheses My Submissions Question Total Accepted: 74274 Total Submissions: 211279...

LeetCode 22-Generate Parentheses

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

leetcode 22. Generate Parentheses

C语言实现

LeetCode_22---Generate Parentheses

LeetCode

LeetCode 22. Generate Parentheses 题解 —— Java

题目链接:https://leetcode.com/problems/generate-parentheses/#/description 题目要求:给定正整数n,求n对括号所有正确配对的组合。 思路...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:LeetCode 22:Generate Parentheses
举报原因:
原因补充:

(最多只允许输入30个字)