【Generate Parentheses】cpp

题目:

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:

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

代码:

复制代码
class Solution {
public:
        vector<string> generateParenthesis(int n)
        {
            vector<string> ret;
            vector<char> tmp;
            Solution::dfs(ret, tmp, 0, n, n, n);
            return ret;
        }
        static void dfs( vector<string>& ret, vector<char>& tmp, int sum, int left, int right, int n )
        {
            if ( left==0 && right==0 )
            {
                ret.push_back(string(tmp.begin(),tmp.end()));
                return;
            }
            // '(' or ')'
            if ( left>0 )
            {
                tmp.push_back('(');
                Solution::dfs(ret, tmp, sum+1, left-1, right, n);
                tmp.pop_back();
            }
            if ( right>0 && sum>0 )
            {
                tmp.push_back(')');
                Solution::dfs(ret, tmp, sum-1, left, right-1, n);
                tmp.pop_back();
            }
        }

};
复制代码

tips:

第一反应是不是stack相关的解法,因为感觉跟逆波兰表达式差不多。

后来发现用‘深搜+剪枝’即可解决。

这里left表示没有使用的'(',right表示没有使用的')';sum标记使用left和right的情况,使用一次left给sum加1,使用一次right给sum减1。

能迭代下去的核心条件是:使用的sum必须大于等于0.

1. 深搜情况,这里每层有两个分支:'(' 或者 ')'

2. 剪枝条件:

  a) 只要使用过'('小于n, 则可以加到tmp中

  b) 使用过的')'小于n, 并且当前的sum是大于0的

=======================================

第二次用dfs过这道题,套路稍微熟悉一些了,考虑dfs的分支顺序:每一层可以加入left括号也可以加入right括号,终止条件的是剩余的left括号数量一定小于right括号的数量。

posted on   承续缘  阅读(168)  评论(0编辑  收藏  举报

编辑推荐:
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
阅读排行:
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

统计

点击右上角即可分享
微信分享提示