【算法三十六】131. 分割回文串

131. 分割回文串

回溯:

java 复制代码
class Solution {
    public List<List<String>> partition(String s) {
        List<List<String>> ans = new ArrayList<>();
        List<String> path = new ArrayList<>();
        backtrack(s,ans,path,0);
        return ans;
    }

    //回溯:
    //终止条件
    //非终止条件:
    //子问题 当前操作(要做什么) 下一个子问题是什么 恢复现场 
    private void backtrack(String s,List<List<String>> ans,List<String> path,int l){
        if(l==s.length()){
            //一定要复制,因为path是一块可以反复擦用的黑板,不然最后就是空的
            ans.add(new ArrayList<>(path));
            return;
        }
        for(int r=l;r<s.length();r++){
            if(palindrome(s,l,r)){
                path.add(s.substring(l,r+1));
                backtrack(s,ans,path,r+1);
                path.remove(path.size() - 1);
            }
        }
    }

    private boolean palindrome(String s,int l,int r){
        while(l<r){
            if(s.charAt(l)!=s.charAt(r)){
                return false;
            }
            l++;
            r--;
        }
        return true;
    }
}

时间复杂度:O(N*2^N) N是字符串长度

空间复杂度:O(N)

相关推荐
金銀銅鐵6 小时前
[Python] 扩展欧几里得算法
python·数学·算法
To_OC9 小时前
LC 200 岛屿数量:经典 DFS 入门题,我第一次写居然连方向都搞错了
javascript·算法·leetcode
To_OC1 天前
LC 128 最长连续序列:别上来就排序,O (n) 解法才是这题的灵魂
javascript·算法·leetcode
05Kevin2 天前
lk每日冒险题--数据结构6.27
算法
To_OC2 天前
从一次栈溢出报错说起,我把递归彻底扒明白了
javascript·算法·程序员
千纸鹤安安2 天前
千问Qwen-AgentWorld来了:一个语言模型搞定七大Agent场景,GPT-5.4都输了
算法
七牛开发者2 天前
MCP 到底是什么?为什么 Agent 都想接上它
算法·aigc·agent