henryzhihua

关注图像处理、模式识别、机器学习与计算机视觉 ps:本来你努力就能得到的东西,不要因为懈怠而失去机会!...

LeetCode 22: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,生成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); //当左括号比右括号个数多时,可以添加右括号,递归处理
	}

};



阅读更多
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/geekmanong/article/details/49928621
所属专栏: LeetCode算法分析
想对作者说点什么? 我来说一句

没有更多推荐了,返回首页

不良信息举报

LeetCode 22:Generate Parentheses

最多只允许输入30个字

加入CSDN,享受更精准的内容推荐,与500万程序员共同成长!
关闭
关闭