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

算法 括号生成-(递归回溯+同向双指针)

牛客网: BM60

N对括号的所有合法组合

解题思路:

使用双指针进行递归回溯获取所有可能组合,left指代"(",right指代")",均从0开始,left先行,left > right时,添加")"合法,right可前进,当left与right均递增到n时,获取一个有效组合。边界条件使用if判断。

代码:

// go

package main
// import "fmt"

/**
 * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
 *
 * 
 * @param n int整型 
 * @return string字符串一维数组
*/

var res = []string{}

func process(left, right, n int, tmp string) {
    if left == n && right == n {
        res = append(res, tmp)
        return
    }
    if left < n {
        process(left+1, right, n, tmp+"(")
    }
    if right < n && left > right {
        process(left, right+1, n, tmp+")")
    }
}

func generateParenthesis( n int ) []string {
    // write code here
    if n == 0 {
        return []string{}
    }
    left := 0
    right := 0
    tmp := ""
    process(left, right, n, tmp)
    return res
}

相关文章:

  • 解决仪器掉线备忘
  • 希望杯、希望数学系列竞赛辨析和希望数学超1G的真题和学习资源
  • 邮件功能-python中的SMTP协议邮件发送
  • Ubuntu Postgresql开机自启动服务
  • 在北京多有钱能称为富
  • ubuntu20.04 安装 pyconcorde
  • SpringCloud 学习(一)简介和环境搭建
  • Linux下gdb常规调试
  • 如何办一份有价值的企业内刊/报纸?向《华为人》学习就够了
  • 06_ElasticSearch:索引和文档的CURD
  • 【力扣2154】将找到的值乘以 2
  • 小皮面板配置Xdebug,调试单个php文件
  • 解决LiveData数据倒灌的新思路
  • 使用datax将数据从InfluxDB抽取到TDengine过程记录
  • Qt QCustomPlot介绍
  • 基于SpringBoot的药房管理系统
  • springboot基于SpringBoot的冬奥会科普平台springboot21
  • 购物H5商城架构运维之路
  • 数据结构--单链表
  • 蓝桥杯 题库 简单 每日十题 day7
  • “6+2”小复式追加票!松江购彩者擒大乐透1672万头奖
  • 外媒:罗马教皇方济各去世
  • 独家丨远洋渔船船长被害案嫌犯移送检方报捕,船上两段视频曝光
  • 解放日报:订单不撤,中国工程师有能力
  • 画廊主韦尔:是喜是伤的一生
  • “云南舞蹈大家跳”暨牟定“三月会”下周举行,城际公交免票