【算法刷题 | 回溯思想 04】4.15(分割回文串)

文章目录

7.分割回文串

7.1题目

给你一个字符串 s,请你将 s 分割成一些子串,使每个子串都是 回文串 。返回 s 所有可能的分割方案。

  • 示例一:

    输入:s = "aab"
    输出:[["a","a","b"],["aa","b"]]

  • 示例二:

    输入:s = "a"
    输出:[["a"]]

7.2解法:回溯

7.2.1回溯思路

例如对于字符串abcdef:

  • 组合问题:选取一个a之后,在bcdef中再去选取第二个,选取b之后在cdef中再选取第三个...。
  • 切割问题:切割一个a之后,在bcdef中再去切割第二段,切割b之后在cdef中再切割第三段...。
(1)函数返回值以及参数
java 复制代码
private void backing(String s,int startIndex)
(2)终止条件
  • 若要切割的位置已经超出数组范围,则添加该路径下的回文串

  • res:全部符合条件的回文串组合

  • paths:当前分割路径的回文串组合

java 复制代码
if(startIndex > s.length()-1){
	res.add(new ArrayList(paths));
}
(3)遍历过程
java 复制代码
for(int i=startIndex;i<s.length();i++){
	//判断当前段是否为回文
    if(isPalindrome(s,startIndex,i)){
        
        //获取 [startIndex,i]的子串
        String str=s.substring(startIndex,i+1);
        paths.add(str);
    }else{
        continue;
    }
    
    backing(s,i+1);
    
    //回溯
    paths.remove(paths.size()-1);
}
  • 判断是否为回文串方法:
java 复制代码
private boolean isPalindrome(String s,int start,int end){
	for(;start<end;start++,end--){
        if(s.charAt(start)!=s.charAt(end)){
            return false;
        }
    }
    return true;
}

7.2.2代码

java 复制代码
	List<List<String>> res=new ArrayList<>();
    List<String> paths=new ArrayList<>();

    public List<List<String>> partition(String s) {
        backing(s,0);
        return res;
    }

    private void backing(String s,int startIndex){
        if(startIndex>s.length()-1){
	        res.add(new ArrayList(paths));
            return;
        }  

        for(int i=startIndex;i<s.length();i++){
	        //判断当前段是否为回文
            if(isPalindrome(s,startIndex,i)){
        
                //获取 [startIndex,i]的子串
                String str=s.substring(startIndex,i+1);
                paths.add(str);
            }else{
                continue;
            }
    
            backing(s,i+1);
    
            //回溯
            paths.remove(paths.size()-1);
        }      
    }

    private boolean isPalindrome(String s,int start,int end){
	    for(;start<end;start++,end--){
            if(s.charAt(start)!=s.charAt(end)){
                return false;
            }
        }
        return true;
    }
相关推荐
SuniaWang4 分钟前
《Spring AI + 大模型全栈实战》学习手册系列 · 专题六:《Vue3 前端开发实战:打造企业级 RAG 问答界面》
java·前端·人工智能·spring boot·后端·spring·架构
sheji341612 分钟前
【开题答辩全过程】以 基于springboot的扶贫系统为例,包含答辩的问题和答案
java·spring boot·后端
88号技师14 分钟前
2026年3月中科院一区SCI-贝塞尔曲线优化算法Bezier curve-based optimization-附Matlab免费代码
开发语言·算法·matlab·优化算法
t1987512815 分钟前
三维点云最小二乘拟合MATLAB程序
开发语言·算法·matlab
无敌昊哥战神16 分钟前
【LeetCode 257】二叉树的所有路径(回溯法/深度优先遍历)- Python/C/C++详细题解
c语言·c++·python·leetcode·深度优先
m0_726965981 小时前
面面面,面面(1)
java·开发语言
x_xbx1 小时前
LeetCode:148. 排序链表
算法·leetcode·链表
Darkwanderor1 小时前
三分算法的简单应用
c++·算法·三分法·三分算法
2401_831920741 小时前
分布式系统安全通信
开发语言·c++·算法
xuhaoyu_cpp_java1 小时前
过滤器与监听器学习
java·经验分享·笔记·学习