分割回文串

力扣题目链接

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

回文串 是正着读和反着读都一样的字符串。

示例 1:

输入:s = "aab"

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

示例 2:

输入:s = "a"

输出:[["a"]]

思路

题意很好理解

这里主要有两个问题:

​ 1、怎么去切割字符串(即切割的方式)

​ 2、怎么判断回文

切割字符串

第一个问题老生常谈了,用for有局限性,所以用回溯

对照一下前面应用回溯来找组合的操作:

(组合)选取一个a之后,在bcdef中再去选取第二个,选取b之后在cdef中再选取第三个.....。

(切割)切割一个a之后,在bcdef中再去切割第二段,切割b之后在cdef中再切割第三段.....。

其实本质上是一样的

虽然说是这么说,但实际上是哪个东西执行的“切”这个动作呢?

因为我们需要指定遍历位置,因此和之前的问题一样需要使用beginIndex

而这个beginIndex就是“切割线”

例如:

在单层处理时,我们需要使用for来遍历字符串嘛,就有以下情况:

aabaa
↑ ↑
bI i

因为在初始化for的条件时,i是等于beginIndex的,经过循环,i会不断自增,相当于“切割线”不断右移

每次遍历,我们将当前字符串s的[beginIndex, i]区间输入给一个回文判断函数

若当前区间代表的子串是回文串,那么就使用substr函数将其截取下来保存

题外话:substr函数

该函数的简介

其输入是一个区间,举个例子:

test_str = "abb";
test_str.substr(0, 1);//cout->"a"
test_str.substr(0, 2);//cout->"ab"
test_str.substr();//cout->"abb"

可见,substr获取的子串是左闭右开的,即右边界的元素不获取

判断回文串

双指针法,没什么好说的

将待判断的子串的区间传入,作为遍历时的左右指针,然后遍历判断即可

//回文判断函数
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;
}

代码

还是按回溯三部曲来写,直接给出代码了

有问题的地方详见注释

class Solution {
private:
//定义回文判断函数
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>> res;
vector<string> path;
//确定回溯函数的参数和返回值
void backtracking(string& s, int beginIndex){
//确定终止条件
//如果起始位置已经大于s的大小,说明已经找到了一组分割方案了
if(beginIndex >= s.size()){
res.push_back(path);
return;
}
//确定单层处理逻辑
for(int i = beginIndex; i < s.size(); ++i){
//判断当前串是否为回文串
if(isPalindrome(s, beginIndex, i)){//是回文串
//获取s中从beginIndex到当前切割位置的子串
//使用substr函数
//i - beginIndex + 1是当前"切割线"的位置
string cutStr = s.substr(beginIndex, i - beginIndex + 1);
path.push_back(cutStr);
}else{
continue;//不是回文串就跳过
}
backtracking(s, i + 1);//递归
path.pop_back();//回溯
}
}
public:
vector<vector<string>> partition(string s) {
backtracking(s, 0);
return res;
}
};

【LeetCode回溯算法#05】分割回文串(复习双指针判断回文以及substr函数使用记录)的更多相关文章

  1. 力扣算法:125-验证回文串,131-分割回文串---js

    LC 125-验证回文串 给定一个字符串,验证它是否是回文串,只考虑字母和数字字符,可以忽略字母的大小写. 说明:本题中,我们将空字符串定义为有效的回文串. 注:回文串是正着读和反着读都一样的字符串. ...

  2. 【LeetCode回溯算法#07】子集问题I+II,巩固解题模板并详解回溯算法中的去重问题

    子集 力扣题目链接 给你一个整数数组 nums ,数组中的元素 互不相同 .返回该数组所有可能的子集(幂集). 解集 不能 包含重复的子集.你可以按 任意顺序 返回解集. 示例 1: 输入:nums ...

  3. 【LeetCode回溯算法#06】复原IP地址详解(练习如何处理边界条件,判断IP合法性)

    复原IP地址 力扣题目链接(opens new window) 给定一个只包含数字的字符串,复原它并返回所有可能的 IP 地址格式. 有效的 IP 地址 正好由四个整数(每个整数位于 0 到 255 ...

  4. 【XSY2715】回文串 树链剖分 回文自动机

    题目描述 有一个字符串\(s\),长度为\(n\).有\(m\)个操作: \(addl ~c\):在\(s\)左边加上一个字符\(c\) \(addr~c\):在\(s\)右边加上一个字符 \(tra ...

  5. 51Nod - 1154 回文串划分(最少回文串dp)

    回文串划分 有一个字符串S,求S最少可以被划分为多少个回文串. 例如:abbaabaa,有多种划分方式.   a|bb|aabaa - 3 个回文串 a|bb|a|aba|a - 5 个回文串 a|b ...

  6. BZOJ 3676 [Apio2014]回文串 (后缀自动机+manacher/回文自动机)

    题目大意: 给你一个字符串,求其中回文子串的长度*出现次数的最大值 明明是PAM裸题我干嘛要用SAM做 回文子串有一个神奇的性质,一个字符串本质不同的回文子串个数是$O(n)$级别的 用$manach ...

  7. 回溯算法————n皇后、素数串

    回溯就是算法是搜索算法中一种控制策略,是一个逐个试探的过程.在试探的过程中,如果遇到错误的选择,就会回到上一步继续选择下一种走法,一步一步的进行直到找到解或者证明无解为止. 如下是一个经典回溯问题n皇 ...

  8. LeetCode简单算法之分割平衡字符串 #1221

    在一个「平衡字符串」中,'L' 和 'R' 字符的数量是相同的. 给出一个平衡字符串 s,请你将它分割成尽可能多的平衡字符串. 返回可以通过分割得到的平衡字符串的最大数量. 示例 1: 输入:s = ...

  9. 【LeetCode回溯算法#extra01】集合划分问题【火柴拼正方形、划分k个相等子集、公平发饼干】

    火柴拼正方形 https://leetcode.cn/problems/matchsticks-to-square/ 你将得到一个整数数组 matchsticks ,其中 matchsticks[i] ...

  10. 【LeetCode回溯算法#08】递增子序列,巩固回溯算法中的去重问题

    递增子序列 力扣题目链接(opens new window) 给定一个整型数组, 你的任务是找到所有该数组的递增子序列,递增子序列的长度至少是2. 示例 1: 输入:nums = [4,6,7,7] ...

随机推荐

  1. shell补遗_一个巨简单的保证服务存活的脚本

    Shell补遗 背景 公司一台机器总是会在没有更新补丁的情况下启动失败. 查看所有的配置都没有问题. 但是就是不启动 没办法,准备写一个检查进行启动. 最近写shell很少. 所以总结一下. 思路 判 ...

  2. [转帖]龙芯总强调同频性能,是因奔腾4要到25+GHz才比得上酷睿11代单核

      https://baijiahao.baidu.com/s?id=1734320620568707041 闲话不说,先上图,是SPEC CPU 2006 int(单任务)测试的成绩: 上图中的成绩 ...

  3. [转帖]如何在本地编译安装部署自动化回归测试平台 AREX

    https://zhuanlan.zhihu.com/p/613877597 AREX 官方 QQ 交流群:656108079 本文将详细为大家介绍一下自动化回归测试平台 AREX 以及如何在本地进行 ...

  4. WebAssembly入门笔记[1]:与JavaScript的交互

    前一阵子利用Balazor开发了一个NuGet站点,对WebAssembly进行了初步的了解,觉得挺有意思.在接下来的一系列文章中,我们将通过实例演示的方式介绍WebAssembly的一些基本概念和编 ...

  5. Hutool中那些常用的工具类和实用方法

    背景 灵魂拷问1:还在为新项目工具类搬迁而烦恼? 灵魂拷问2:还在为项目中工具类维护而烦恼? 简述 **Hutool**它是一个Java工具集类库,包含了很多静态方法的封装:流处理.时间日期处理.正则 ...

  6. KubeSphere2.1踩坑记

    至少两台机器.推荐4X16.(完全安装KubeSphere会吃掉10G+内存) k8s安装(略1.14.8)可参考我上一篇文章或者基于kubeadmin快速安装 KubeSphere2.1前置条件 1 ...

  7. IdentityServer4 系列文章01---密码授权模式

    IdentityServer4实现.Net Core API接口权限认证(快速入门)   什么是IdentityServer4 官方解释:IdentityServer4是基于ASP.NET Core实 ...

  8. 西门子PLC高校作业以及创新项目

    抢答器 在主持人按下启动按钮,3秒内

  9. Linux下的gcc/g++编译器的使用 [补档-2023-06-13]

    gcc编译器 ​ 这东西是Linux上的c/c++编译器. 5-1 gcc的工作流程 5-2 gcc的常用参数 -v 查看gcc版本号, --version也可以 -E 生成预处理文件 -S 生成汇编 ...

  10. 【树】N叉树的遍历【力扣589、力扣590】超详细的解释和注释

    说在前面 欢迎朋友们来到我的博客. 今天我们的重点是,N叉树的遍历. 今天,博主就带来两道经典的题目,领着大家理解N叉树的前序遍历和后序遍历! 当然,还想学习其它算法的朋友们,可以通过订阅博主的算法专 ...