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/

相关推荐
浅念-1 小时前
递归解题指南:LeetCode经典题全解析
数据结构·算法·leetcode·职场和发展·排序算法·深度优先·递归
Kiling_07042 小时前
Java集合进阶:Set与Collections详解
算法·哈希算法
智者知已应修善业2 小时前
【51单片机89C51及74LS273、74LS244组成】2022-5-28
c++·经验分享·笔记·算法·51单片机
洛水水2 小时前
【力扣100题】33.验证二叉搜索树
算法·leetcode·职场和发展
SimpleLearingAI2 小时前
聚类算法详解
算法·数据挖掘·聚类
刀法如飞3 小时前
Go 字符串查找的 20 种实现方式,用不同思路解决问题
算法·面试·程序员
Dlrb12115 小时前
C语言-指针数组与数组指针
c语言·数据结构·算法·指针·数组指针·指针数组·二级指针
WL_Aurora5 小时前
Python 算法基础篇之集合
python·算法
平行侠5 小时前
A15 工业路由器IP前缀高速检索与内存压缩系统
网络·tcp/ip·算法
阿旭超级学得完7 小时前
C++11包装器(function和bind)
java·开发语言·c++·算法·哈希算法·散列表