当前位置: 首页 > news >正文

分割回文串(回溯算法)

本文参考代码随想录

给定一个字符串 s,将 s 分割成一些子串,使每个子串都是回文串。

返回 s 所有可能的分割方案。

示例: 输入: “aab” 输出: [ [“aa”,“b”], [“a”,“a”,“b”] ]

思路

切割字符串问题也可以转换成回溯算法:即切割后再在子串上切割
在这里插入图片描述
判断回文字符串:双指针法
一个指针从前向后,一个指针从后向前,如果前后指针所指向的元素是相等的,就是回文字符串

class Solution {
private:vector<vector<string>> result;vector<string> path;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;}void backtracking(string s, int startIndex){if(startIndex >= s.size()){result.push_back(path);return;}for(int i = startIndex; i < s.size(); i++){if(isPalindrome(s, startIndex, i)){string ss = s.substr(startIndex, i - startIndex + 1);path.push_back(ss);backtracking(s, i + 1);path.pop_back();}else{continue; //不是回文}}} 
public:vector<vector<string>> partition(string s) {path.clear();result.clear();backtracking(s, 0);return result;}
};
http://www.xdnf.cn/news/1209511.html

相关文章:

  • 智能制造的空间度量:机器视觉标定技术解析
  • 26考研英语词汇的逻辑笔记(Unit31-43)
  • 如何进行项目复盘?核心要点分析
  • 新升级超值型系列32位单片机MM32G0005
  • R语言中 read.table 和 read.delim 之间的区别
  • 机器学习-贝叶斯函数(理解版)
  • B 站搜一搜关键词优化:精准触达用户的流量密码
  • 牛顿拉夫逊法PQ分解法计算潮流MATLAB程序计算模型。
  • Go语言新手村:轻松理解变量、常量和枚举用法
  • 从centos更换至ubuntu的安装、配置、操作记录
  • 【iOS】类扩展与关联对象
  • 嵌入式学习日志(十一)
  • Kafka——消费者组重平衡全流程解析
  • 数据库-索引
  • 13、select_points_object_model_3d解析
  • 安卓逆向2-安卓刷机和获取root权限和安装LSPosed框架
  • Linux安装ragflow(含一键安装脚本)
  • vue中使用wavesurfer.js绘制波形图和频谱图
  • sqli-labs通关笔记-第25关GET字符注入(过滤or和and 脚本法)
  • buuctf_crypto26-30
  • 基于变频与移相混合控制(PFM+PSM)的全桥LLC谐振变换器仿真模型
  • 车载诊断架构 --- 关于诊断时间参数P4的浅析
  • QML 3D曲面图(Surface3D)技术
  • K-近邻算法(KNN算法)的K值的选取--交叉验证+网格搜索
  • 【C++算法】72.队列+宽搜_二叉树的最大宽度
  • adb reboot 与 adb shell svc power reboot 的区别
  • 【C++】1. C++基础知识
  • 【HTML】浅谈 script 标签的 defer 和 async
  • 企业高性能web服务器
  • EnergyMath芯详科技 EMS4100/MES4000/MES3900