Leetcode: Generate parentheses

简介:

输入n,输出n个左括号和n个右括号的合法括号序列

关键:当前位置的左括号不少于右括号

图:

  节点:当前位置左括号和右括号的个数(x, y)(x>=y)

  边:从(x, y)到(x+1, y)或(x,y+1)

  x==y时,只有(x+1,y)这条边

解:从(0,0)出发到(n,n)的全部路径

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

C++

DFS

记录什么

  左右括号的个数

  当前的部分解

复制代码
 1 class Solution {
 2 public:
 3     void helperDFS(int n, int x, int y, string now, vector<string> &ans) {
 4         if (y == n) {
 5             ans.push_back(now);
 6             return;
 7         }
 8         if (x < n) {
 9             helperDFS(n, x + 1, y, now + "(", ans);
10         }
11         if (x > y) {
12             helperDFS(n, x, y + 1, now + ")", ans);
13         }
14         
15     }
16     vector<string> generateParenthesis(int n) {
17         vector<string> ans;
18         helperDFS(n, 0, 0, "", ans);
19         return ans;
20     }
21 };
复制代码

C++

BFS

  记录什么

  方法1:当前的部分解

  方法2:每个节点记录能到达它之前的节点集合(麻烦,最后还要还原路径)

复制代码
 1 struct node{
 2     int x, y;
 3     string now;
 4 };
 5 class Solution {
 6 public:
 7     void helperBFS(int n, vector<string> &ans) {
 8         if (0 == n) {
 9             ans.push_back("");
10             return;
11         }
12         node tmp;
13         tmp.x = tmp.y = 0;
14         tmp.now = "";
15         queue<node> q;
16         for (q.push(tmp); !q.empty(); q.pop()) {
17             tmp = q.front();
18             node other;
19             if (tmp.x < n) {
20                 other.x = tmp.x + 1;
21                 other.y = tmp.y;
22                 other.now = tmp.now + "(";
23                 q.push(other);
24             }
25             if (tmp.x > tmp.y) {
26                 other.x = tmp.x;
27                 other.y = tmp.y + 1;
28                 other.now = tmp.now + ")";
29                 if (other.y == n) {
30                     ans.push_back(other.now);
31                 } else {
32                     q.push(other);
33                 }
34             }
35         }
36         
37     }
38     vector<string> generateParenthesis(int n) {
39         vector<string> ans;
40         helperBFS(n, ans);
41         return ans;
42     }
43 };
复制代码

 

本文转自ZH奶酪博客园博客,原文链接:http://www.cnblogs.com/CheeseZH/p/5012102.html,如需转载请自行联系原作者

相关文章
|
5天前
|
人工智能 运维 安全
|
3天前
|
人工智能 异构计算
敬请锁定《C位面对面》,洞察通用计算如何在AI时代持续赋能企业创新,助力业务发展!
敬请锁定《C位面对面》,洞察通用计算如何在AI时代持续赋能企业创新,助力业务发展!
|
10天前
|
人工智能 JavaScript 测试技术
Qwen3-Coder入门教程|10分钟搞定安装配置
Qwen3-Coder 挑战赛简介:无论你是编程小白还是办公达人,都能通过本教程快速上手 Qwen-Code CLI,利用 AI 轻松实现代码编写、文档处理等任务。内容涵盖 API 配置、CLI 安装及多种实用案例,助你提升效率,体验智能编码的乐趣。
839 109
|
4天前
|
机器学习/深度学习 人工智能 自然语言处理
B站开源IndexTTS2,用极致表现力颠覆听觉体验
在语音合成技术不断演进的背景下,早期版本的IndexTTS虽然在多场景应用中展现出良好的表现,但在情感表达的细腻度与时长控制的精准性方面仍存在提升空间。为了解决这些问题,并进一步推动零样本语音合成在实际场景中的落地能力,B站语音团队对模型架构与训练策略进行了深度优化,推出了全新一代语音合成模型——IndexTTS2 。
454 12
|
3天前
|
人工智能 测试技术 API
智能体(AI Agent)搭建全攻略:从概念到实践的终极指南
在人工智能浪潮中,智能体(AI Agent)正成为变革性技术。它们具备自主决策、环境感知、任务执行等能力,广泛应用于日常任务与商业流程。本文详解智能体概念、架构及七步搭建指南,助你打造专属智能体,迎接智能自动化新时代。
|
4天前
|
机器学习/深度学习 传感器 算法
Edge Impulse:面向微型机器学习的MLOps平台——论文解读
Edge Impulse 是一个面向微型机器学习(TinyML)的云端MLOps平台,致力于解决嵌入式与边缘设备上机器学习开发的碎片化与异构性难题。它提供端到端工具链,涵盖数据采集、信号处理、模型训练、优化压缩及部署全流程,支持资源受限设备的高效AI实现。平台集成AutoML、量化压缩与跨硬件编译技术,显著提升开发效率与模型性能,广泛应用于物联网、可穿戴设备与边缘智能场景。
188 127