关闭

LeetCode 22:Generate Parentheses

305人阅读 评论(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,生成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); //当左括号比右括号个数多时,可以添加右括号,递归处理
	}

};



0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:300091次
    • 积分:4402
    • 等级:
    • 排名:第7066名
    • 原创:156篇
    • 转载:34篇
    • 译文:1篇
    • 评论:83条
    博主描述
    关注图像处理、模式识别、机器学习与计算机视觉,对稀疏表示和图像超分辨率技术很感兴趣,有相同研究的朋友,欢迎加入图像超分辨率技术交流讨论QQ群:524940170
    博客专栏
    最新评论