LeetCode:131. 分割回文串

跟着carl学算法,本系列博客仅做个人记录,建议大家都去看carl本人的博客,写的真的很好的!
代码随想录
LeetCode:131. 分割回文串

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

示例 1:

输入:s = "aab"

输出:[["a","a","b"],["aa","b"]]

示例 2:

输入:s = "a"

输出:[["a"]]

其实这题和前面的组合问题还是类似的,只是这里加了个切割字符串并且判断是否回文的概念,需要注意子串怎么切割,这里是左闭右开的,index~i + 1这个区间的就是子串

java 复制代码
	public List<List<String>> partition(String s) {
        List<List<String>> res = new ArrayList<>();
        backtracking(s, 0, new ArrayList<>(), res);
        return res;
    }

    private void backtracking(String s, int index, List<String> path, List<List<String>> res) {
        if (index == s.length()) {
            res.add(new ArrayList(path));
            return;
        }
        for (int i = index; i < s.length(); i++) {
            if (isPalindrome(s, index, i)) {
                path.add(s.substring(index, i + 1));
                backtracking(s, i + 1, path, res);
                path.remove(path.size() - 1);
            }
        }
    }

    private boolean isPalindrome(String s, int start, int end) {
        while (start <= end) {
            if (s.charAt(start) != s.charAt(end)) {
                return false;
            }
            start++;
            end--;
        }
        return true;
    }
相关推荐
Java成神之路-1 分钟前
【算法刷题笔记】全题型导航目录
笔记·算法
爱写代码的倒霉蛋2 分钟前
2022年天梯赛L1-8真题解析(哈希+排序)
数据结构·算法
Struggle_97559 分钟前
算法知识-倍增算法
算法
计算机安禾13 分钟前
【计算机网络】第5篇:网桥学习与生成树算法——环路拓扑中的路径收敛问题
学习·计算机网络·算法
fie888915 分钟前
基于遗传算法的机械故障诊断MATLAB程序
算法·机器学习·matlab
咖啡八杯18 分钟前
GoF设计模式——单例模式
java
0xDevNull18 分钟前
JDK多版本切换安装与配置
java·后端
nlpming20 分钟前
opencode MCP(Model Context Protocol)配置手册
算法
流年似水~20 分钟前
Java新手5分钟接AI:Spring AI Alibaba实战
java·人工智能·spring
DarkAthena24 分钟前
【YaShanDB】给YaShanDB开发R2DBC驱动
java·yashandb·r2dbc