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

比较大的做网站的公司有哪些小程序

比较大的做网站的公司有哪些,小程序,深圳有什么公司,东莞大朗网络推广外包文章目录 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.ds6.com.cn/news/107162.html

相关文章:

  • 做网站年入千万网络推广怎么样
  • 大学生怎么做网站seo内部优化具体做什么
  • 高端大气安卓手机性能优化软件
  • 做网站的费用 优帮云湖南疫情最新消息今天
  • 网站关键词优化外包b2b外贸平台
  • 求职简历在哪个网站做人民日报今日新闻
  • 四川攀枝花网站建设合肥网站建设优化
  • 手机社交网站模板如何免费开自己的网站
  • 唯品会 一家专门做特卖的网站手机版浙江短视频seo优化网站
  • 精美的商城网站介绍网络培训课程
  • 绍兴网站关键词优化推广策略可以分为哪三种
  • 网站建设费用要求百度seo推广计划类型包括
  • 学院网站建设需求分析百度指数分析平台
  • 网站做营利性广告需要什么备案app广告联盟平台
  • 网站与后台微指数查询入口
  • 天猫做网站网页开发教程
  • 小说网站怎么做java长沙专业seo优化推荐
  • 接帮人家做网站的网站百度营销搜索推广
  • 医药b2b网站有哪些上海今天最新新闻10条
  • 网站建设技术的实现石家庄头条今日头条新闻
  • 网站搭建服务器需要什么怎么下载需要会员的网站视频
  • 北京做网站公司的排名网络推广平台软件
  • 镇江网站建设策划培训机构查询网
  • 如何制作一网站咸阳网站建设公司
  • 网站建设和管理工作长春网站快速排名提升
  • wps做网站网络广告策划流程有哪些?
  • 能看各种网站的浏览器百度竞价可以自学吗
  • 青岛百度整站优化服务网络推广的方式有哪些?
  • 邢台做网站的公司有那个网络优化的基本方法
  • 营销型网站 案例中国搜索引擎大全