当前位置: 首页 > 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
  • 结婚这件事,年轻人到底怎么想的?
  • 国台办:台商台企有信心与国家一起打赢这场关税战
  • 工业富联一季度净利增长25%,云计算业务营收增长超50%
  • 中国人民解放军南部战区位南海海域进行例行巡航
  • 交行一季度净利253.72亿元增1.54%,不良率微降
  • 外交部官方公众号发布视频:不跪!