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/

相关推荐
2301_764441334 小时前
基于AI的本地文件归档智能管理工具梳理
人工智能·python·算法·目标检测·交互
无限码力4 小时前
美团研发岗 4月18号笔试真题 - 包包的最长公共子序列3
算法·美团笔试题·美团研发岗笔试题·美团机试题
怪兽学LLM4 小时前
LeetCode 21 合并两个有序链表:彻底理解虚拟头节点(Dummy)套路
python·leetcode·链表
阿里matlab建模师4 小时前
基于matlab时域频域处理的语音信号变声处理系统设计与算法原理(论文+程序源码+GUI图形用户界面)——变声算法
算法·matlab·语音识别
IMPYLH4 小时前
HTML 的 <abbr> 元素
前端·算法·html
leo__5205 小时前
小波特征与模糊支持向量机(FSVM)的脑电信号分类方法
算法·支持向量机·分类
wabs6665 小时前
关于动态规划【纯粹的0-1背包需要思考的问题】
算法·动态规划
小小编程路5 小时前
字符串转数字时,可能会遇到哪些问题?
java·开发语言·算法
rit84324995 小时前
MATLAB近红外光谱预处理:平滑与求导(MSV方法)
数据结构·算法·matlab
蚂蚁数据AntData5 小时前
从ChatBI到业务记忆:重新定义数据智能的生产力边界
大数据·网络·数据库·人工智能·算法