IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> 力扣LeetCode:22. 括号生成(Python、Java) -> 正文阅读

[数据结构与算法]力扣LeetCode:22. 括号生成(Python、Java)

题目描述

数字 n 代表生成括号的对数,请你设计一个函数,用于能够生成所有可能的并且 有效的 括号组合。

示例

输入:n = 3
输出:[“((()))”,“(()())”,“(())()”,“()(())”,“()()()”]

输入:n = 1
输出:[“()”]

思路一:更大的n对应的括号怎样由更小的n得到?

题解

因为需要生成所有的可能性,因此这里是一个动态规划。下面问题的关键,即动规思路。

那么,更大的n对应的括号怎样由更小的n得到呢?不能遗漏,也不要重复。我们从易到难地分析:

一个括号:()
两个括号:(()) ()()
三个括号:((())) (()()) (())() ()(()) ()()()

观察到这样一种规律:

f(n) = ‘(’ + f(i) + ‘)’ ∪ f(n - 1 - i) , 0 <= i < n

我们自小到大地枚举i,因此不会出现重复的字符串。分析到这里,可以使用动态规划或者递归的形式实现。动规以空间换时间,效率更高。

Java代码

写于2020年1月:

class Solution {
    public List<String> generateParenthesis(int n) {
        List<String> ans = new ArrayList();
        if (n == 0) {
            ans.add("");
        } else {
            for (int c = 0; c < n; ++c)
                for (String left: generateParenthesis(c))
                    for (String right: generateParenthesis(n-1-c))
                        ans.add("(" + left + ")" + right);
        }
        return ans;
    }
}

Python代码

写于2022年4月:

class Solution(object):
    def generateParenthesis(self, n):
        if n == 0:
            return ['']
        rs = []
        for i in range(n):
            left = self.generateParenthesis(i)
            right = self.generateParenthesis(n - i - 1)
            for l in left:
                for r in right:
                    rs.append('(' + l + ')' + r)
        return rs

思路二:逐字符拓展

题解

换一种思路,我们思考含n对括号的字符串在什么情况下是合规的:

  • 必须有n个左括号与n个右括号。
  • 自左向右,在任何位置,之前的左括号数目一定要大于右括号数目。

我们基于上面这两点,从前向后,通过逐字符拓展,即一个个加入左括号与右括号的方法,最终生成所有可能性。由于存在多种可能性,也就对应着每次可以新加入一个左括号、也可以新加入一个右括号,这些分支有些最终不能走通(这些不可行的分支对应不符合上述两点条件的情况),所以非常适合用递归实现。

对于递归函数,我们记录当前的字符串是什么、记录当前已经加入了多少个左括号与多少个右括号。对于符合条件的字符串,我们把它加入结果中。

Java代码

写于2020年1月:

import java.util.ArrayList;
import java.util.List;

class Solution {
	void dfs(int l,int r,int n,String curr,List<String> list) {
		if(l<r)	return;
		if(l>n||r>n)	return;
		if(l==n&&r==n) {
			list.add(curr);
			return;
		}
		dfs(l+1,r,n,curr+"(",list);
		dfs(l,r+1,n,curr+")",list);
	}
	
    public List<String> generateParenthesis(int n) {
        List<String> list=new ArrayList<String>();
        dfs(0,0,n,"",list);
        return list;
    }
}

Python代码

写于2022年4月:

class Solution(object):
    rs = []

    def dfs(self, l_num, r_num, n, curr):
        if l_num > n or r_num > n or r_num > l_num:
            return
        if l_num == n and r_num == n:
            self.rs.append(curr)
            return
        self.dfs(l_num + 1, r_num, n, curr + '(')
        self.dfs(l_num, r_num + 1, n, curr + ')')


    def generateParenthesis(self, n):
        self.rs = []
        self.dfs(0, 0, n, '')
        return self.rs
  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2022-05-04 07:30:14  更:2022-05-04 07:30:33 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/4 15:45:10-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码