1.题目链接:

131. 分割回文串

2.解题思路:

2.1.题目要求:

给一个字符串 s ,要求把 s 分割成一些子串,并使每个子串都是 回文串。

回文串的概念:正反顺序都一样的字符串。

举例:

输入:s = "aab"

输出:[["a","a","b"],["aa","b"]]

2.2.思路:

for+递归构成 n叉树,用于查找每一份字串组合,再补充 判断是不是回文串的逻辑,以及终止条件的确认

n叉树如下:

2.3.回溯三部曲:

2.3.1.确定回溯函数参数

path存储一条分割方案的字符串,result是字符串结果集。

参数默认输入 s ,startIndex 用于避免重复切割和切割过程中字串范围确定。

vector<vector<string>> result;
vector<string> path; // 放已经回文的子串
void backtracking (const string& s, int startIndex) {

2.3.2.确定终止条件

当切割完最后一个字符串字符的时候,说明已经找到了一组分割方案了,返回到结果集里。

那什么是作为切割完最后一个字符的判断条件?

startIndex >= s.size( ) ,因为 startIndex 在单层遍历逻辑里,记录每次递归的起始位置,到最下面一层的递归时,startIndex 默认是等于 s.size( ) 就停止了的,但大于的情况是怎么产生的?我的理解是 xxxxxx

void backtracking (const string& s, int startIndex) {// 如果起始位置已经大于s的大小,说明已经找到了一组分割方案了if (startIndex >= s.size()) {result.push_back(path);return;}
}

2.3.3.确定单层遍历逻辑

这里搜集不同的分割方案,以及判断当下递归的for搜集的每一段字符串是不是符合回文串的定义,不符合就跳过并继续循环。

判断回文子串的范围是如何确定的?

因为每一次递归,搜集指针 i 都从 startIndex 的位置出发(startIndex每次递归都会更新)然后 i 向后遍历,直到末尾,在这个情况下 不断更新的 i 和 在非递归的情况下不动的 startIndex 的位置形成的范围,就可以不断判断是不是回文串了,是就搜集,不是就跳过

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();        // 回溯过程,弹出本次已经填在的子串
}

判断回文子串的函数 isPalindrome 用的是双指针法

代码如下:

bool isPalindrome(const 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;}

2.4.总代码:

class Solution {
private:vector<vector<string>> result;vector<string> path; // 放已经回文的子串void backtracking (const 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(); // 回溯过程,弹出本次已经填在的子串}}bool isPalindrome(const 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;}
public:vector<vector<string>> partition(string s) {result.clear();path.clear();backtracking(s, 0);return result;}
};

3.记录:

中文感觉没精神写,写的没气力,果然休息会儿,晚上写就好的多的多了,依情况而定,不能强来。

006. 分割回文串相关推荐

  1. LeetCode-笔记-131. 分割回文串

    LeetCode-笔记-131. 分割回文串 131. 分割回文串 给你一个字符串 s,请你将 s 分割成一些子串,使每个子串都是 回文串 .返回 s 所有可能的分割方案. 回文串 是正着读和反着读都 ...

  2. 怎么判断一个字符串的最长回文子串是否在头尾_LeetCode 第 131 号问题:分割回文串...

    题目来源于 LeetCode 上第 131 号问题:分割回文串.题目难度为 Medium,目前通过率为 45.8% . 题目描述 给定一个字符串 s,将 s 分割成一些子串,使每个子串都是回文串. 返 ...

  3. 132. 分割回文串 II

    链接:132. 分割回文串 II 题解:https://leetcode-cn.com/problems/palindrome-partitioning-ii/solution/xiang-tong- ...

  4. 131. 分割回文串

    链接:131. 分割回文串 题解:https://leetcode-cn.com/problems/palindrome-partitioning/solution/hui-su-fa-si-lu-y ...

  5. 【python】一道LeetCode搞懂递归算法!#131分割回文串 #以及刷LeetCode的一点点小心得 [数据结构与算法基础]

    题目:给定一个字符串 s,将 s 分割成一些子串,使每个子串都是回文串.返回 s 所有可能的分割方案. # 示例 输入: "aab" 输出: [["aa",&q ...

  6. 【回文串问题】分割回文串

    Leetcode:131. 分割回文串 - 力扣(LeetCode) (leetcode-cn.com) 分为两部分: 1.动态规划确定子串是否是回文串 2.枚举子集 时间复杂度:O(n*2^n) 空 ...

  7. LeetCode 1278. 分割回文串 III

    截止到目前我已经写了 600多道算法题,其中部分已经整理成了pdf文档,目前总共有1000多页(并且还会不断的增加),大家可以免费下载 下载链接:https://pan.baidu.com/s/1hj ...

  8. Suzy找到实习了吗 Day27 | 回溯进行中:39. 组合总和,40. 组合总和 II,131.分割回文串

    39. 组合总和 题目 给你一个 无重复元素 的整数数组 candidates 和一个目标整数 target ,找出 candidates 中可以使数字和为目标数 target 的 所有 不同组合 , ...

  9. 【回溯法】python 实现 全排列,子集,组合问题、分割回文串

    leetcode39.40.47. 78. 77.131 目录 47:全排列 78:子集 39组合总和 40 组合总和 77组合 131 分割回文串 47:全排列 全排列问题:  使用回溯法,需要注意 ...

最新文章

  1. 解决AndroidStudio2.0导入eclipse项目时卡死的问题
  2. AutoLayout的那些事儿
  3. 如何用python做一个会聊天的女朋友_520来啦~教你用Python给自己造了一个女朋友!...
  4. postman传数组参数
  5. Windows 7 SP1 旗舰版 MSDN原版
  6. 云南昆明企业等保合规安全解决方案、等保二级、等保三级解决方案
  7. Matlab取整函数之Floor\fix\round\ceil取余函数rem\mod
  8. java 成员变量什么时候初始化_Java中成员变量的初始化过程
  9. 【应用推荐】如何选择适合自己的笔记应用?附热门笔记应用上手总结
  10. 电脑使用者的眼睛保护须知
  11. 《Neural Collaborative Filtering》NCF模型的理解以及python代码
  12. 深度硬核,思维导图拯救拖延症患者!
  13. 可穿戴式柔性电子应变传感器(二)
  14. 数据库异常状态:Recovery Pending,Suspect,估计Recovery的剩余时间
  15. C++ 开发【梦幻西游】500多行代码实现
  16. 计算机启动显示不正确的分区表,每次开机提示invalid partition table怎么解决?
  17. IntelliJ IDEA 查看数据库插件(很强大的一个插件)
  18. Anaconda3 jupyter 警告:FutureWarning: reshape is deprecated and will raise in a subsequent release.
  19. Flash和E2PROM的区别
  20. 台湾海峡隧道三条规划线路集体加速

热门文章

  1. 类ku6未注册域名分享
  2. 简易PC基准测试丨PerformanceTest功能简介
  3. 13.创建活动、布局、活动关联布局、注册活动
  4. 新人成长:实习一个月感悟
  5. java aes ecb_java使用AES加密解密 AES-128-ECB加密
  6. 从有道云笔记迁移到另一个有道云笔记账号
  7. pscc2018安装服务器无响应,强大的功能无法使用,大神教你一招解决PSCC2018无法安装扩展插件...
  8. Word2003入门动画教程25:添加或改变Word页面边框
  9. elasticsearch删除过期数据
  10. CSS颜色代码大全及a标签超链接颜色改变