【刷题1】LeetCode 131. 分割回文串 java题解

2024: 刚开始做leetcode hot100,查阅自己以前写的题解专栏,发现没有这一题,于是加上。可能leetcode100更新了吧。我看现在leetcode100官网的题目已经是分好类的了,以前我的题解帖子是自己手动分类整理的。

java 复制代码
class Solution {
    List<List<String>> res;
    public List<List<String>> partition(String s) {
        res=new ArrayList<>();
        dfs(new ArrayList<String>(),s);
        return res;
    }
    public void dfs(ArrayList<String> tmp,String s){
        //剩下要处理的
        if(s==null||s.length()==0){
            res.add(new ArrayList(tmp));
            return;
        }
        for(int i=1;i<=s.length();i++){
            //a是已分割,b是未分割
            String a=s.substring(0,i);
            String b="";
            if(i<s.length())
                b=s.substring(i);
            if(isPalindrome(a)){
                tmp.add(a);
                dfs(tmp,b);
                tmp.remove(tmp.size()-1);
            }
        }
    }
    //判断是否是回文
    public boolean isPalindrome(String s){
        if(s.length()==0||s.length()==1) return true;
        int i=0,j=s.length()-1;
        while(i<=j){
            if(s.charAt(i)!=s.charAt(j)){
                return false;
            }
            i++;
            j--;
        }
        return true;
    }
}
相关推荐
代码不停3 小时前
BFS解决拓扑排序和FloodFill问题
java·算法·宽度优先
TL滕3 小时前
从0开始学算法——第二十一天(复杂链表问题)
笔记·学习·算法
Chengbei113 小时前
CVE-2025-24813 Tomcat 最新 RCE 分析复现
java·安全·web安全·网络安全·tomcat·系统安全·网络攻击模型
AAA简单玩转程序设计3 小时前
救命!Java 进阶居然还在考这些“小儿科”?
java·前端
sin_hielo3 小时前
leetcode 955
数据结构·算法·leetcode
总是学不会.4 小时前
【JUC编程】多线程学习大纲
java·后端·开发
MediaTea4 小时前
思考与练习(第十章 文件与数据格式化)
java·linux·服务器·前端·javascript
7澄14 小时前
Maven 项目拆分与聚合实战:分层架构下的多模块开发
java·架构·maven·service·dao·pojo·数据库连接
TechNomad4 小时前
二分搜索算法的介绍和使用
算法
一起养小猫4 小时前
LeetCode100天Day4-盛最多水的容器与两数之和II
java·数据结构·算法·leetcode