算法设计与分析(15) -- Generate Parentheses(难度:Medium)
来源:互联网 发布:类似皮影客的软件 编辑:程序博客网 时间:2024/05/19 23:54
算法设计与分析(15)
题目: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对圆括号组合的形式是否合法:给一个由n对圆括号组合成的字符串,则当我们把这个字符串截取为两段,无论从任何点截取,截取后的第一段中左括号的数量肯定大于等于右括号的数量。只有满足上述的条件,这个组合才是合法的。
2. 这里我们就可以使用上面的思路使用递归的方式构建所有的有效形式。取string str
为生成的结果,int left
为剩余需要插入的左括号熟练,int right
为剩余需要插入的右括号数量。所以我们很容易得到:若
(1)left == 0 且 right == 0,那么我们已经生成一个由n对圆括号组合的有效形式,把其存入结果中:
(2)如果 left!=0,那么插入左括号是合法的;并且考虑当right>left,既当剩余需要插入的右括号数量大于剩余的左括号数量,那么插入右括号也是合法的。
void generate(vector<string> &result, string str, int left, int right){ if (left == 0 && right == 0) { result.push_back(str); } else { if (left != 0) generate(result, str + "(", left - 1, right); if (right > left) generate(result, str + ")", left, right - 1); }}
(3)最后就可以得到所有的有效组合。
实现代码:
#include<iostream>#include<vector>#include<string>using namespace std;void generate(vector<string> &result, string str, int left, int right){ if (left == 0 && right == 0) { result.push_back(str); } else { if (left != 0) generate(result, str + "(", left - 1, right); if (right > left) generate(result, str + ")", left, right - 1); }}vector<string> generateParenthesis(int n) { vector<string> result; generate(result, "", n, n); return result;}int main(){ int n = 3; vector<string> result; result = generateParenthesis(n); for (int i = 0; i < result.size(); ++i) cout << result[i] << endl; return 0;}
阅读全文
0 0
- 算法设计与分析(15) -- Generate Parentheses(难度:Medium)
- (算法分析Week11)Generate Parentheses[Medium]
- 算法设计与分析(1)-- Add Two Numbers(难度:Medium)
- 算法设计与分析(2) -- String to Integer(难度:Medium)
- 算法设计与分析(4)-- Longest Substring Without Repeating Characters(难度:Medium)
- 算法设计与分析(5)-- Longest Palindromic Substring(难度:Medium)
- 算法设计与分析(6)-- ZigZag Conversion(难度:Medium)
- 算法设计与分析(8)-- Container With Most Water(难度:Medium)
- 算法设计与分析(9)-- 3Sum(难度:Medium)
- 算法设计与分析(10)-- 3Sum Closest(难度:Medium)
- 算法设计与分析(11)-- Letter Combinations of a Phone Number(难度:Medium)
- 算法设计与分析(12)-- 4Sum(难度:Medium)
- 算法设计与分析(13)-- Remove Nth Node From End of List(难度:Medium)
- 算法设计与分析(17)-- Swap Nodes in Pairs(难度:Medium)
- 算法设计与分析(14)-- Valid Parentheses(难度:Easy)
- 第十六周算法分析与设计:Generate Parentheses
- 算法分析与设计丨第一周丨LeetCode(2)——Different Ways to Add Parentheses(Medium)
- LeetCode刷题(C++)——Generate Parentheses(Medium)
- 剑指offer 面试题30 最小的 k 个数
- JNDI
- U-boot在S3C2440上的移植详解(一)
- 【机房重构】--职责链模式+策略模式 实现下机
- 1015: 二次方程的实根
- 算法设计与分析(15) -- Generate Parentheses(难度:Medium)
- jqueryMobile 按钮
- API(Calendar类)
- 动态规划测试test20170518
- 『ORACLE』移动数据(Directory Object)
- CGLib 介绍与原理
- Bmob的本地缓存用户注意事项
- 1016: 银行利率
- 关于抽象