当前位置: 首页 > news >正文

注册网站会有哪些风险最好大连网站建设

注册网站会有哪些风险,最好大连网站建设,商贸公司起名字大全免费,wordpress cms 模板制作文章目录 1. 题目2. 思路及代码实现(Python)2.1 暴力法2.2 回溯法 1. 题目 数字 n n n 代表生成括号的对数,请你设计一个函数,用于能够生成所有可能的并且 有效的 括号组合。 示例 1: 输入: n 3 n 3 …

文章目录

  • 1. 题目
  • 2. 思路及代码实现(Python)
    • 2.1 暴力法
    • 2.2 回溯法


1. 题目

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

示例 1:

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

示例 2:

输入: n = 1 n = 1 n=1
输出: [ " ( ) " ] ["()"] ["()"]


提示

  • 1 ≤ n ≤ 8 1 \leq n \leq 8 1n8

2. 思路及代码实现(Python)

2.1 暴力法

该思路先生成所有的 2 2 n 2^{2n} 22n 个 “(” 和 “)” 字符串构成的序列,然后检查生成的序列是否有效,一共有 n n n 对括号,共 2 n 2n 2n 个字符,每个位置存在两种不同的选择,因此总共有 2 2 n 2^{2n} 22n 种序列。

为了生成所有序列,可以使用递归。长度为 n n n 的序列就是在长度为 n − 1 n−1 n1 的序列后加一个 “(” 或 “)”。为了检查序列是否有效,我们遍历这个序列,并使用一个变量 b a l bal bal 表示左括号的数量减去右括号的数量。如果在遍历过程中 b a l bal bal 的值小于零,或者结束时 b a l bal bal 的值不为零,那么该序列就是无效的,否则它是有效的。前者说明,遍历一段字符串时出现 “)” 大于 “(” 的数量,显然说明该子串不能成对;而后者说明整个字符串的左右括号数并不相等。

该算法的时间复杂度为: O ( 2 2 n n ) O(2^{2n}n) O(22nn),对于 2 2 n 2^{2n} 22n 个序列中的每一个,对其进行有效性的验证的复杂度为 O ( n ) O(n) O(n)。而空间复杂度除了存储答案组之外,还需要存储探索答案的栈深,复杂度为 O ( n ) O(n) O(n)

class Solution:def generateParenthesis(self, n: int):def generate(A):if len(A) == 2*n:if valid(A):ans.append("".join(A))else:A.append('(')generate(A)A.pop()A.append(')')generate(A)A.pop()def valid(A):bal = 0for c in A:if c == '(': bal += 1else: bal -= 1if bal < 0: return Falsereturn bal == 0ans = []generate([])return ans

执行用时:71 ms
消耗内存:16.54 MB

2.2 回溯法

上述方法是遍历生成所有的可能的序列,然后再进行判断,这里我们发现有可以改进的地方,就是在生成序列时,提前跟踪序列的左右括号的数据,来决定扩展序列时所选择的括号。例如,已有子序列的左括号数量不大于 n n n,则可以放置左括号,如果右括号数量小于左括号数量,可以放置一个右括号。

该算法的复杂度分析依赖于该有效序列可以回溯出 的元素个数。这证明是第 n n n 个卡特兰数 1 n + 1 ( 2 n n ) \dfrac{1}{n+1}\dbinom{2n}{n} n+11(n2n) ,这是由 4 n n n \dfrac{4^n}{n\sqrt{n}} nn 4n 渐近界定的。因此时间复杂度为 O ( 4 n n ) O(\dfrac{4^n}{\sqrt{n}}) O(n 4n)。空间复杂度为保存答案和保存栈深的消耗,为 O ( n ) O(n) O(n)

class Solution:def generateParenthesis(self, n: int):ans = []def backtrack(S, left, right):if len(S) == 2 * n:ans.append(''.join(S))returnif left < n:S.append('(')backtrack(S, left+1, right)S.pop()if right < left:S.append(')')backtrack(S, left, right+1)S.pop()backtrack([], 0, 0)return ans

执行用时:42 ms
消耗内存:16.55 MB


题解来源:力扣官方题解

http://www.yayakq.cn/news/654464/

相关文章:

  • 网站 怎么备案wordpress安装器
  • 网站推广方案模板wps的ppt做网站超链接
  • 郑州设计师网站大全网站建设需要注意哪些细节
  • 包头学做网站购物网站建设案件
  • 网站模板哪个网站全面重庆网站建设招标
  • 哪个网站做长图免费转高清Wordpress模板服务
  • 凉山州建设厅官方网站长春专业做网站的公司有哪些
  • 株洲网站排名优化企业网站运营推广
  • p2p贷款网站开发网站数据修改
  • 东莞做网站哪家好房产网站怎么做
  • 什么免费推广网站好公司网站内容规划
  • 综合门户网站建设天津建筑工程信息
  • 网站 带数据广告联盟怎么建设网站
  • edm营销网站建设项目自主验收网站
  • 温州网站建设优化需要做网站的企业电话
  • 网站建设模板设计中企动力z云邮登录
  • 扬州专业做网站企业梵克雅宝什么档次
  • 网站博客程序阳泉集团网站建设
  • 深圳设计网站开发wordpress php7主题
  • 定制网站的优势驻马店做网站建设的公司
  • 网站维护主要需要会什么职业培训机构排名
  • 抢注域名网站做网站用微软雅黑
  • 台州市住房和城乡建设局网站中国机械加工外协网
  • 网站建设项目的预算一个网站开发流程图
  • 化妆品公司的网站建设策划书免费域名注册平台
  • 怎样建设营销型网站可信的专业网站建设
  • 沙漠风网站建设公司专业拓客公司联系方式
  • 天津做一个简单的网站首页广州番禺专业做网站
  • 海南所有的网站建设类公司在线网页代理浏览器
  • 律师网站建设公司互联网外包平台