【LeetCode热题100(59/100)】分割回文串

题目地址: 链接

思路: 依然是简单的递归回溯(枚举所有组合,逐个检查组合中的每个字符串是否为回文串)

js 复制代码
/**
 * @param {string} s
 * @return {string[][]}
 */

let isP = (arr) => {
    for(let str of arr) {
        let n = str.length;
        let m = Math.floor(str.length / 2);
        for(let i = 0; i < m; i ++) {
            if(str[i] !== str[n - 1 - i]) {
                return false;
            }
        }
    }
    return true;
}
var partition = function(s) {
    let ans = [];
    let n = s.length;
    const dfs = (idx, arr) => {
        if(idx == n) {
            ans = [...arr];
            return;
        }
        
        let arrLen = arr.length;
        for(let i = 0; i < arrLen; i ++) {
            let subarr = arr[i];
            arr.push([...subarr, s[idx]]);
            let m = subarr.length;
            subarr[m - 1] += s[idx];
        }
        if(arr.length == 0) arr.push([s[idx]]);
        dfs(idx + 1, arr);
    }

    dfs(0, [])

    let res = [];
    for(const subAns of ans) {
        if(isP(subAns)) res.push(subAns);
    }

    return res;
};
相关推荐
wuweijianlove12 小时前
算法教学中的抽象建模与动态可视化设计的技术7
算法
2zcode12 小时前
基于改进YOLO11算法的芯片微缺陷检测系统(UI界面+数据集+分析界面+处置建议+训练代码)
算法·芯片缺陷
leoufung12 小时前
LeetCode 30:Substring with Concatenation of All Words 题解(含 C 语言 uthash 实现)
c语言·leetcode·c#
王老师青少年编程13 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【哈夫曼贪心】:荷马史诗
c++·算法·贪心·csp·信奥赛·哈夫曼贪心·荷马史诗
样例过了就是过了13 小时前
LeetCode热题100 最小路径和
c++·算法·leetcode·动态规划
Aaron158813 小时前
RFSOC+VU13P+GPU 在6G互联网中的技术应用
大数据·人工智能·算法·fpga开发·硬件工程·信息与通信·信号处理
迷途之人不知返13 小时前
Stack & Queue
c++·算法
没文化的阿浩13 小时前
【数据结构】排序(2)——直接选择排序、堆排序
数据结构·算法·排序算法
ytttr87314 小时前
基于libusb的用户空间UVC相机库
算法
bybitq14 小时前
Reactor 模型 vs Proactor 模型:区别与代码示例
算法