LeetCode hot100 -131.分割回文串

.先定义了答案集合ans,和路径path。开始调用dfs递归函数。

如果i来到了结尾s.length的位置代表结束将path加入到ans当中。如果i<s的最后一个字符就继续向深层次遍历。最后到达最后一个字符的位置开始回溯,判断从start到i是否是回文串,是就分割,不是就继续向前回溯。举例abb

start = 0, i = 2时判断abb不是回文串,回溯到 i= 0时,a是回文串分割。然后i和satrt均+1,

start = 1, i = 1进入dfs,在进入i+1,此时i= 2,判断bb是回文串,分割。得到最终结果加入到ans.

回溯到start = i = 1时,刚才进入的是不分割,现在继续向下执行分割,判断b是回文串就分割,继续加1,b又是回文串,继续分割,加入ans。就结束了。

java 复制代码
class Solution {
    public List<List<String>> partition(String s) {
        List<List<String>> ans = new ArrayList<>();
        List<String> path = new ArrayList<>();
        dfs(0,0,s,path,ans);
        return ans;
    }
    private void dfs(int i,int start,String s,List<String> path,List<List<String>> ans){
        if(i == s.length()){
            ans.add(new ArrayList<>(path));
            return ;
        }
        //不分割
        if(i < s.length() - 1){
            dfs(i+1,start,s,path,ans);
        }
        //分割
        if(isPalindrome(s,start,i)){
            path.add(s.substring(start,i+1));
            dfs(i+1,i+1,s,path,ans);
            path.removeLast();
        }

    }
    private boolean isPalindrome(String s,int left,int right){
        while(left < right){
            if(s.charAt(left++) != s.charAt(right--)){
                return false;
            }
        }
        return true;
    }
}

还有第二种方法,可参考:

作者:灵茶山艾府 链接:https://leetcode.cn/problems/palindrome-partitioning/solutions/2059414/hui-su-bu-hui-xie-tao-lu-zai-ci-pythonja-fues/

相关推荐
贾斯汀玛尔斯2 小时前
每天学一个算法--PageRank
算法
子琦啊2 小时前
【算法复习】滑动窗口(同向区间指针)
算法
啊我不会诶2 小时前
【自用复习】牛客每日一题2026.4.18 最大稳定数值
算法·深度优先
数智化精益手记局2 小时前
8d报告案例分析:拆解8d报告案例分析的8个步骤,解决生产现场重复发生的质量难题
大数据·数据结构·数据库·人工智能·精益工程
笨笨饿2 小时前
66_C语言与微控制器底层开发
linux·c语言·网络·数据结构·算法·机器人·个人开发
AI人工智能+电脑小能手2 小时前
【大白话说Java面试题】【Java基础篇】第10题:HashMap中的元素是有序存放的吗
java·开发语言·数据结构·后端·面试·哈希算法·哈希表
yong99902 小时前
双连杆机械臂阻抗控制仿真
算法·仿真
牢姐与蒯3 小时前
c++数据结构之二叉搜索树
数据结构·c++·搜索
李可以量化3 小时前
Python之如何做出交易日历(上)
人工智能·算法·qmt·量化 qmt ptrade