代码随想录——分割回文串(Leetcode 131)

题目链接

回溯

java 复制代码
class Solution {
    List<List<String>> res = new ArrayList<List<String>>();
    List<String> list= new ArrayList<String>();
    public List<List<String>> partition(String s) {
        backtracking(s, 0);
        return res;
    }
    public void backtracking(String s, int startIndex){
        if(startIndex >= s.length()){
            res.add(new ArrayList<>(list));
            return;
        }
        for(int i = startIndex; i < s.length(); i++){
            // 如果是回文数,则继续回溯
            if(is(s, startIndex, i)){
                list.add(s.substring(startIndex, i + 1));
            }else{
                continue;
            }
            backtracking(s, i + 1);
            list.removeLast();
        }
    }
    // 判断回文数
    public boolean is(String s, int start, int end){
        for(int i = start, j = end; i < j; i++, j--){
            if(s.charAt(i) != s.charAt(j)){
                return false;
            }
        }
        return true;
    }
}
相关推荐
hope_wisdom2 分钟前
C/C++数据结构之队列基础
c语言·数据结构·c++·队列·queue
不会聊天真君6475 分钟前
设计模式、线程状态、上下文切换、线程安全(JAVA并发第二期)
java
Swift社区7 分钟前
死锁:线程卡死不是偶然,而是设计问题
java·spring·maven
不一样的故事1267 分钟前
高速采集箱
算法·信号处理
uup7 分钟前
防止短信验证码接口被盗刷问题
java
xxxmine14 分钟前
ConcurrentHashMap 和 Hashtable 的区别详解
java·开发语言
凛_Lin~~14 分钟前
安卓 面试八股文整理(原理与性能篇)
android·java·面试·安卓
weixin_4365250724 分钟前
NestJS-TypeORM QueryBuilder 常用 SQL 写法
java·数据库·sql
oioihoii26 分钟前
C++虚函数表与多重继承内存布局深度剖析
java·jvm·c++
会员果汁35 分钟前
算法-拓扑排序-C
c语言·开发语言·算法