【LeetCode热题100】【回溯】分割回文串

题目链接:131. 分割回文串 - 力扣(LeetCode)

要找出所有分割这个字符串的方案使得每个子串都是回文串,写一个判断回文串的函数,深度遍历回溯去找出所有分割方案,判断分割的子串是否是回文串

复制代码
class Solution {
public:
    vector<vector<string> > ans;
    vector<string> an;
    string s;

    bool isPalindromes(int left, int right) {
        while (left < right) {
            if (s[left++] != s[right--])
                return false;
        }
        return true;
    }

    void dfs(int i) {
        if (i == s.size()) {
            ans.push_back(an);
            return;
        }
        for (int j = i; j < s.size(); ++j) {
            if (isPalindromes(i, j)) {
                an.push_back(s.substr(i, j - i + 1));
                dfs(j + 1);
                an.pop_back();
            }
        }
    }

    vector<vector<string> > partition(string s) {
        this->s = move(s);
        dfs(0);
        return ans;
    }
};
相关推荐
玖日大大几秒前
ModelEngine 可视化编排实战:从智能会议助手到企业级 AI 应用构建全指南
大数据·人工智能·算法
月明长歌4 分钟前
【码道初阶】Leetcode面试题02.04:分割链表[中等难度]
java·数据结构·算法·leetcode·链表
如竟没有火炬5 分钟前
快乐数——哈希表
数据结构·python·算法·leetcode·散列表
TL滕7 分钟前
从0开始学算法——第十四天(数组与搜索练习)
笔记·学习·算法
SoleMotive.11 分钟前
bio、nio、aio的区别以及使用场景
python·算法·nio
一招定胜负19 分钟前
机器学习算法二:逻辑回归
算法·机器学习·逻辑回归
星诺算法备案19 分钟前
算法备案材料:明晰材料逻辑,构建安全合规的算法体系
人工智能·算法·推荐算法·备案
another heaven22 分钟前
【软考 cache映射】主存容量
算法
ULTRA??23 分钟前
判断水仙花数并输出,c++
c++·算法
Arva .25 分钟前
G1收集器
java·jvm·算法