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

牛客网: 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
}

你可能感兴趣的:(牛客网,算法刷题,括号生成,递归回溯)