算法-回溯篇06-分割回文串

分割回文串

力扣题目链接

题目描述

给你一个字符串 s,请你将 s 分割成一些 子串,使每个子串都是 回文串 。返回 s 所有可能的分割方案。

解题思路

这里不同于前几道题目,思路改了一下;

解题步骤:

  • isHuiWen函数用于判断字符串是不是回文串;
  • 开始进入回溯函数;
  • 当剩余的字符串的长度为0的时候,把存入的分割子串放入答案列表;
  • 定义一个临时字符串temp,数据是s从begin()到begin() + i;(这里需要注意迭代器的边界判断,搞了很久,最后本地调试了一下才过)
  • 然后判断temp是不是回文串,如果是切割掉temp,把剩余的子串传入回溯函数;
  • 如果不是回文串,继续遍历减少temp的长度,直到长度为1。

题解

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

    bool isHuiWen(string s){
        if(s.size() == 1){
            return true;
        }
        int lp = 0, rp = s.size() - 1;
        while(lp < rp){
            if(s[lp] != s[rp]){
                return false;
            }
            lp++;
            rp--;
        }

        return true;
    }

    void BackTrack(string s){
        if(s.size() == 0){
            ans.push_back(path);
            return;
        }
        for(int i = s.size(); i >= 1; i--){
            string temp(s.begin(), s.begin() + i);
            if(isHuiWen(temp)){
                string nexts(s.begin() + i, s.end());
                path.push_back(temp);
                BackTrack(nexts);
                path.pop_back();
            }            
        }

        return;
    }

    vector<vector<string>> partition(string s) {
        BackTrack(s);
        return ans;        
    }
};
相关推荐
月亮被咬碎成星星1 分钟前
LeetCode[226] 翻转二叉树
算法·leetcode
KingQian201819 分钟前
单片机嵌入式滤波算法库
单片机·嵌入式硬件·算法
瑞雪兆丰年兮1 小时前
数学实验(Matlab语言环境和线性代数实验)
算法·数学建模·matlab·数学实验
烨然若神人~2 小时前
算法训练营第十一天|150. 逆波兰表达式求值、239. 滑动窗口最大值、347.前 K 个高频元素
算法
天天爱吃肉82182 小时前
机器学习经典算法:用决策树原理优化新能源汽车续航能力
算法·决策树·机器学习
金融小师妹2 小时前
AI技术视角:美联储信号与黄金动态的量化研究——基于多模态数据分析框架
大数据·人工智能·算法
蓝婷儿2 小时前
前端面试每日三题 - Day 28
前端·面试·职场和发展
dot to one2 小时前
C++ 深入解析 数据结构中的 AVL树的插入 涉及的旋转规则
数据结构·c++·算法·visual studio·avl树
电院大学僧2 小时前
初学python的我开始Leetcode题8-4
python·算法·leetcode
MeteorSaraphines2 小时前
第 14 届蓝桥杯 C++ 青少组省赛中 / 高级组真题解析
java·算法