博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Generate Parentheses--生成匹配括号(重)
阅读量:4106 次
发布时间:2019-05-25

本文共 949 字,大约阅读时间需要 3 分钟。

问题:

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:

"((()))", "(()())", "(())()", "()(())", "()()()"

解答:

DFS,关键在于如何生成下一个树。

生成规则:  按顺序添加括号,左括号数量必定要大于等于右括号数量,否则的话不是匹配的括号对,剪枝。

如果左括号已经添加够n个,那么只需要继续添加右括号。

如果不是,那么添加左括号,或右括号,继续向下搜索。

如果左右括号数量都等于n,那么生成了一个可用的匹配。

参考:

代码:

class Solution {public:    vector
generateParenthesis(int n) { string str = ""; vector
str_list; DFS(str, 0, 0, n, str_list); return str_list; } void DFS(string str, int left, int right, int n, vector
&str_list) { if(left < right) return; if(left == n && right == n) { str_list.push_back(str); } else { if(left == n) DFS(str+")", left, right+1, n, str_list); else { DFS(str+")", left, right+1, n, str_list); DFS(str+"(", left+1, right, n, str_list); } } }};

转载地址:http://pktsi.baihongyu.com/

你可能感兴趣的文章
内容里面带标签,在HTML显示问题,JSTL
查看>>
VS编译器运行后闪退,处理方法
查看>>
用div+css做下拉菜单,当鼠标移向2级菜单时,为什么1级菜单的a:hover背景色就不管用了?
查看>>
idea 有时提示找不到类或者符号
查看>>
ng-class的几种用法
查看>>
node入门demo-Ajax让前端angularjs/jquery与后台node.js交互,技术支持:mysql+html+angularjs/jquery
查看>>
神经网络--单层感知器
查看>>
注册表修改DOS的编码页为utf-8
查看>>
matplotlib.pyplot.plot()参数详解
查看>>
拉格朗日对偶问题详解
查看>>
MFC矩阵运算
查看>>
最小二乘法拟合:原理,python源码,C++源码
查看>>
ubuntu 安装mysql
查看>>
c# 计算器
查看>>
C# 简单的矩阵运算
查看>>
gcc 常用选项详解
查看>>
c++输入文件流ifstream用法详解
查看>>
c++输出文件流ofstream用法详解
查看>>
字符编码:ASCII,Unicode 和 UTF-8
查看>>
firewalld的基本使用
查看>>