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/

相关推荐
To_OC3 小时前
从一行报错开始,把字符串反转、回文算法连带着包装类一起捋明白
javascript·算法·api
LCG米3 小时前
机器人控制系统与运动规划:从RRT算法到ROS move_base实战
算法·机器人
QiLinkOS3 小时前
第三视觉理解徐玉生与他的商业活动(26)
大数据·c++·人工智能·算法·开源协议
手写码匠3 小时前
手写 LLM 结构化输出引擎 —— 从 JSON Schema 约束到类型安全的数据提取
人工智能·深度学习·算法·aigc
zhiSiBuYu05173 小时前
重排序(Rerank)提升检索准确率实战指南
开发语言·python·算法
月疯4 小时前
华为手环的部分功能
算法
郭梧悠4 小时前
算法:有效的括号
python·算法·leetcode
atunet4 小时前
关于算法设计模式的演化与编程范式变迁的技术7
算法·设计模式
Jerry4 小时前
LeetCode 27. 移除元素
算法
旖-旎4 小时前
《LeetCode 1137 第N个泰波那契数 和 LeetCode 三步问题》
c++·算法·leetcode·动态规划