Golang | Leetcode Golang题解之第131题分割回文串

题目:

题解:

Go 复制代码
func partition(s string) (ans [][]string) {
    n := len(s)
    f := make([][]int8, n)
    for i := range f {
        f[i] = make([]int8, n)
    }

    // 0 表示尚未搜索,1 表示是回文串,-1 表示不是回文串
    var isPalindrome func(i, j int) int8
    isPalindrome = func(i, j int) int8 {
        if i >= j {
            return 1
        }
        if f[i][j] != 0 {
            return f[i][j]
        }
        f[i][j] = -1
        if s[i] == s[j] {
            f[i][j] = isPalindrome(i+1, j-1)
        }
        return f[i][j]
    }

    splits := []string{}
    var dfs func(int)
    dfs = func(i int) {
        if i == n {
            ans = append(ans, append([]string(nil), splits...))
            return
        }
        for j := i; j < n; j++ {
            if isPalindrome(i, j) > 0 {
                splits = append(splits, s[i:j+1])
                dfs(j + 1)
                splits = splits[:len(splits)-1]
            }
        }
    }
    dfs(0)
    return
}
相关推荐
简单点了3 小时前
go前后端项目的启动 、打包和部署
开发语言·后端·golang
九江Mgx5 小时前
用 Go 手搓一个 NTP 服务:从“时间混乱“到“精准同步“的奇幻之旅
golang·ntp
im_AMBER6 小时前
Leetcode 33
算法·leetcode·职场和发展
坚持编程的菜鸟8 小时前
LeetCode每日一题——二进制求和
c语言·算法·leetcode
爱coding的橙子12 小时前
每日算法刷题Day77:10.22:leetcode 二叉树bfs18道题,用时3h
算法·leetcode·职场和发展
Swift社区12 小时前
LeetCode 404:左叶子之和(Sum of Left Leaves)
算法·leetcode·职场和发展
一匹电信狗13 小时前
【C++】手搓AVL树
服务器·c++·算法·leetcode·小程序·stl·visual studio
脚踏实地的大梦想家13 小时前
【Go】P11 掌握 Go 语言函数(二):进阶玩转高阶函数、闭包与 Defer/Panic/Recover
开发语言·后端·golang
野蛮人6号14 小时前
力扣热题100道之73矩阵置零
算法·leetcode·矩阵
野蛮人6号14 小时前
力扣热题100道之238除自身以外数组的乘积
算法·leetcode·职场和发展