代码随想录——分割回文串(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;
    }
}
相关推荐
努力学算法的蒟蒻1 分钟前
day64(1.23)——leetcode面试经典150
面试·职场和发展
野生技术架构师2 分钟前
【面试题】为什么 Java 8 移除了永久代(PermGen)并引入了元空间(Metaspace)?
java·开发语言
Leo July2 分钟前
【Java】Java设计模式实战指南:从原理到框架应用
java·开发语言·设计模式
Anastasiozzzz5 分钟前
力扣hot100 20.有效的括号 解析
java·算法·面试·力扣
苦藤新鸡6 分钟前
29.删除倒数第N个节点
数据结构·链表·力扣
brave_zhao9 分钟前
如何解决 Spoon 与 Carte 互联的 UTF-8 编码问题
java
CrazyClaz10 分钟前
负载均衡算法
算法·负载均衡
重生之我是Java开发战士18 分钟前
【数据结构】Map、Set与哈希表底层原理
java·数据结构·散列表
嵌入式小能手19 分钟前
飞凌嵌入式ElfBoard-系统信息与资源之休眠
c语言·开发语言·算法
橘子师兄20 分钟前
C++AI大模型接入SDK—API接入大模型思路
开发语言·数据结构·c++·人工智能