分割回文串(力扣131)

这道题咋一看与之前做过的组合问题不相干,实际上仍然需要用上组合问题的模版。分割操作其实就是组合问题里的递归子集并挑选数字。举个例子:我们有一个字符串1,2,3,4,组合问题中我们先在最开始的集合中选择1,然后递归子集2,3,4,这一步其实就可以模拟分割。我们挑选1,可以理解为在1的后面划了一条分割线,然后继续分割2,3,4。分割过程中,子串的获取可以借助substr这个库函数。这是大致思路,大家可以结合我下面的代码及详细注释理解此题。

代码及详细注释如下:

复制代码
class Solution {
public:
    bool isPalindrome(string& s, int start, int end) {
        for (int i = start, j = end; i < j; i++, j--) {
            if (s[i] != s[j]) {
                return false;
            }
        }
        return true;
     }
    vector<vector<string>> result;
    vector<string> path; // 放已经回文的子串
    void backtracking (string& s, int startIndex) {
        // 如果起始位置已经大于s的大小,说明已经找到了一组分割方案了
        if (startIndex >= s.size()) {
            result.push_back(path);
            return;
        }
        for (int i = startIndex; i < s.size(); i++) {
            if (isPalindrome(s, startIndex, i)) {   // 是回文子串
                // 获取[startIndex,i]在s中的子串
                string str = s.substr(startIndex, i - startIndex + 1);
                path.push_back(str);
            } else {                                // 不是回文,跳过
                continue;
            }
            backtracking(s, i + 1); // 寻找i+1为起始位置的子串
            path.pop_back(); // 回溯过程,弹出本次已经添加的子串
        }
    }
    vector<vector<string>> partition(string s) {
        result.clear();
        path.clear();
        backtracking(s, 0);
        return result;
    }
};
相关推荐
你撅嘴真丑10 小时前
第九章-数字三角形
算法
uesowys10 小时前
Apache Spark算法开发指导-One-vs-Rest classifier
人工智能·算法·spark
ValhallaCoder10 小时前
hot100-二叉树I
数据结构·python·算法·二叉树
董董灿是个攻城狮10 小时前
AI 视觉连载1:像素
算法
智驱力人工智能11 小时前
小区高空抛物AI实时预警方案 筑牢社区头顶安全的实践 高空抛物检测 高空抛物监控安装教程 高空抛物误报率优化方案 高空抛物监控案例分享
人工智能·深度学习·opencv·算法·安全·yolo·边缘计算
孞㐑¥11 小时前
算法——BFS
开发语言·c++·经验分享·笔记·算法
月挽清风11 小时前
代码随想录第十五天
数据结构·算法·leetcode
XX風12 小时前
8.1 PFH&&FPFH
图像处理·算法
NEXT0612 小时前
前端算法:从 O(n²) 到 O(n),列表转树的极致优化
前端·数据结构·算法
代码游侠13 小时前
学习笔记——设备树基础
linux·运维·开发语言·单片机·算法