算法训练营day23(补),回溯3

import (

"sort"

)

39. 组合总和

func combinationSum(candidates \[\]int, target int) \[\]\[\]int {

//存储全部集合

result := make(\[\]\[\]int, 0)

if len(candidates) == 0 {

return result

}

sort.Ints(candidates) //排序后面做剪枝

//存储单次集合

path := make(\[\]int, 0)

var backtrace func(candidates \[\]int, target int, startIndex int)

backtrace = func(candidates \[\]int, target int, startIndex int) {

if target == 0 {

temp := make(\[\]int, len(path))

copy(temp, path)

result = append(result, temp)

return

}

for i := startIndex; i < len(candidates); i++ {

if candidatesi > target { //剪枝

break

}

path = append(path, candidatesi)

backtrace(candidates, target-candidatesi, i)

//回溯处理

path = path:len(path)-1

}

}

backtrace(candidates, target, 0)

return result

}

40. 组合总和 II

func combinationSum2(candidates \[\]int, target int) \[\]\[\]int {

//存储全部集合

result := make(\[\]\[\]int, 0)

if len(candidates) == 0 {

return result

}

sort.Ints(candidates) //排序后面做剪枝

//记录数组每一个元素是否使用过

user := make(\[\]bool, len(candidates))

//存储单次集合

path := make(\[\]int, 0)

var backtrace func(candidates \[\]int, target int, startIndex int)

backtrace = func(candidates \[\]int, target int, startIndex int) {

if target == 0 {

temp := make(\[\]int, len(path))

copy(temp, path)

result = append(result, temp)

return

}

for i := startIndex; i < len(candidates); i++ {

if candidatesi > target { //剪枝

break

}

if i > 0 && candidatesi == candidatesi-1 && useri-1 == false { //过滤重复

continue

}

path = append(path, candidatesi)

useri = true

backtrace(candidates, target-candidatesi, i+1)

//回溯处理

path = path:len(path)-1

useri = false

}

}

backtrace(candidates, target, 0)

return result

}

//判断是否是回文

func isPalindrome(s string) bool {

for i, j := 0, len(s)-1; i < j; i, j = i+1, j-1 {

if si != sj {

return false

}

}

return true

}

131. 分割回文串

func partition(s string) \[\]\[\]string {

//存储全部集合

result := make(\[\]\[\]string, 0)

if len(s) == 0 {

return result

}

//存储单次集合

path := make(\[\]string, 0)

var backtrace func(se string, startIndex int)

backtrace = func(se string, startIndex int) {

if startIndex == len(se) {

temp := make(\[\]string, len(path))

copy(temp, path)

result = append(result, temp)

return

}

for i := startIndex; i < len(se); i++ {

//对字符串进行切割

str := sestartIndex : i+1

if isPalindrome(str) {

path = append(path, str)

backtrace(se, i+1)

//回溯处理

path = path:len(path)-1

}

}

}

backtrace(s, 0)

return result

}

相关推荐
用户6757049885021 小时前
Go 语言里判断字符串为空,90% 的人都写错了!
后端·go
用户6757049885021 小时前
Go 进阶必修:90% 的人都没用对的“表驱动法”
后端·go
BothSavage6 小时前
Trae远程开发中DeepSeek自定义模型4054错误的排查与修复
算法
小林ixn6 小时前
从暴力到KMP:一道题彻底搞懂字符串匹配的前世今生
算法
烬羽7 小时前
字符串算法入门:从反转字符串到回文判断,面试不再慌
算法·面试
先吃饱再说1 天前
判断回文字符串,从一行代码到双指针优化
算法
黄敬峰1 天前
深入理解算法核心:从递归思想、数组扁平化到快速排序
算法
知恒1 天前
Go语言接口与多态
go
知恒1 天前
Go语言变量与数据类型
go