LeetCode-热题100:131. 分割回文串

题目描述

给你一个字符串 s,请你将 s 分割成一些子串,使每个子串都是 回文串 。返回 s 所有可能的分割方案。

示例 1:

输入: s = "aab"
输出: [["a","a","b"],["aa","b"]]

示例 2:

输入: s = "a"
输出: [["a"]]

提示:

  • 1 <= s.length <= 16
  • s仅由小写英文字母组成

代码及注释

go 复制代码
func partition(s string) [][]string {
    // 初始化结果集和当前路径
    res, path := make([][]string, 0), make([]string, 0)
    
    // 定义深度优先搜索函数
    var dfs func(s string, pos int)
    dfs = func(s string, pos int) {
        // 如果已经遍历到字符串的末尾,将当前路径添加到结果集中
        if pos == len(s) {
            tmp := make([]string, len(path))
            copy(tmp, path)
            res = append(res, tmp)
            return
        }

        // 遍历字符串,查找回文子串
        for i := pos; i < len(s); i++ {
            str := s[pos : i+1]
            // 如果找到回文子串,将其添加到路径中,继续搜索
            if isPalindrome(str) {
                path = append(path, str)
                dfs(s, i+1)
                // 回溯,将当前回文子串从路径中移除
                path = path[:len(path)-1]
            }
        }
    }

    // 开始深度优先搜索
    dfs(s, 0)
    
    // 返回结果集
    return res
}

// 判断字符串是否为回文串
func isPalindrome(s string) bool {
    left, right := 0, len(s)-1
    for left < right {
        if s[left] != s[right] {
            return false
        }
        left++
        right--
    }
    return true
}
相关推荐
tankeven1 分钟前
HJ159 没挡住洪水
c++·算法
美式请加冰8 分钟前
斐波那契数列介绍和使用
算法
paeamecium32 分钟前
【PAT】 - Course List for Student (25)
数据结构·c++·算法·pat考试
wen__xvn44 分钟前
力扣洛谷模拟题刷题2
算法·leetcode·职场和发展
漫随流水1 小时前
c++编程:说反话(1009-PAT乙级)
数据结构·c++·算法
计算机安禾1 小时前
【数据结构与算法】第23篇:树、森林与二叉树的转换
c语言·开发语言·数据结构·c++·线性代数·算法·矩阵
温九味闻醉1 小时前
人工智能应用作业1:PPO强化学习算法
人工智能·算法
wfbcg2 小时前
每日算法练习:LeetCode 167. 两数之和 II - 输入有序数组 ✅
算法·leetcode·职场和发展
A~MasterYi3 小时前
深入理解 Microscaling (MX) 格式:从浮点基础到共享指数矩阵乘法
算法·矩阵
yuanlaile3 小时前
Go语言(Golang)2026年3月整理经典面试常见问题面试题汇总,建议收藏
后端·golang·go语言面试题·golang后端开发·2026golang面试