61、回溯-分割回文串

思路:

还是全排列的思路,列出每一种组合,然后验证是否是回文,如果是子串放入path中,在验证其他元素是否也是回文。代码如下:

复制代码
class Solution {
    // 主方法,用于接收一个字符串s并返回所有可能的回文分割方案
    public List<List<String>> partition(String s) {
        List<List<String>> ans = new ArrayList<>(); // 存储所有分割方案的结果列表
        if (s == null || s.isEmpty()) { // 检查输入字符串是否为空
            return ans; // 如果是空字符串,直接返回空的结果列表
        }
        List<String> list = new LinkedList<>(); // 用于临时存储当前探索的分割方案
        process(s, 0, list, ans); // 从索引0开始递归处理字符串
        return ans; // 返回所有可能的回文分割方案
    }

    // 辅助递归方法,用于探索所有可能的分割方式
    private void process(String s, int index, List<String> path, List<List<String>> ans) {
        if (index == s.length()) { // 如果当前索引已经到达字符串末尾
            ans.add(new LinkedList<>(path)); // 将当前分割方案复制到结果列表中
        } else {
            for (int i = index; i < s.length(); i++) { // 遍历所有可能的结束位置
                if (valid(s, index, i)) { // 检查当前子串是否为回文
                    path.add(s.substring(index, i + 1)); // 如果是回文,则添加到当前路径中
                    process(s, i + 1, path, ans); // 递归处理剩余的字符串
                    path.remove(path.size() - 1); // 回溯,移除最后添加的子串,尝试其他可能的分割
                }
            }
        }
    }

    // 判断子串是否为回文的辅助方法
    private boolean valid(String s, int low, int high) {
        while (low < high) { // 使用双指针技术从两端向中间检查
            if (s.charAt(low++) != s.charAt(high--)) { // 如果两端字符不相同
                return false; // 不是回文
            }
        }
        return true; // 所有对应的字符都相同,是回文
    }
}
相关推荐
影视飓风TIM16 小时前
C++ 核心语法笔记:拷贝构造、深浅拷贝与运算符重载
java·开发语言·javascript
极创信息16 小时前
信创产品适配测试认证,域名和SSL是必须的吗?
java·开发语言·网络·python·网络协议·ruby·ssl
大白话_NOI16 小时前
【二分答案】附通用模板
c++·算法
Y学院16 小时前
Java 智能体开发实战:从核心架构到生产级落地,告别AI调用积木式编程
java·人工智能·架构
三行数学16 小时前
数学周刊第23期(2026年06月08日-06月14日)南师数科院万仁辉副教授成果登顶国际数学四大顶刊之一<数学年刊>
算法·数学周刊
阿文的代码库16 小时前
算法专题:独特的电子邮件地址
linux·运维·算法
老饼讲解-BP神经网络16 小时前
BP神经网络用什么训练算法(traingd、traingdm、trainlm)
人工智能·神经网络·算法
Javatutouhouduan16 小时前
2026年Java面试核心讲(终极版)全网首次开源!
java·jvm·java多线程·java面试·后端开发·java程序员·java八股文
山峰哥16 小时前
VBA数据结构之争:Dictionary vs Collection,性能差3倍!
服务器·数据结构·数据库·windows·sql·算法·哈希算法
摇滚侠16 小时前
MyBatis 入门到项目实战 MyBatis 各种查询功能 30-33
java·后端·spring·maven·intellij-idea·mybatis