【算法刷题 | 回溯思想 04】4.15(分割回文串)

news2025/4/15 18:18:22

在这里插入图片描述

文章目录

  • 7.分割回文串
    • 7.1题目
    • 7.2解法:回溯
      • 7.2.1回溯思路
        • (1)函数返回值以及参数
        • (2)终止条件
        • (3)遍历过程
      • 7.2.2代码

7.分割回文串

7.1题目

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

  • 示例一:
输入:s = "aab"
输出:[["a","a","b"],["aa","b"]]
  • 示例二:
输入:s = "a"
输出:[["a"]]

7.2解法:回溯

7.2.1回溯思路

例如对于字符串abcdef:

  • 组合问题:选取一个a之后,在bcdef中再去选取第二个,选取b之后在cdef中再选取第三个…。
  • 切割问题:切割一个a之后,在bcdef中再去切割第二段,切割b之后在cdef中再切割第三段…。
  • image-20240415093449950
(1)函数返回值以及参数
private void backing(String s,int startIndex)
(2)终止条件
  • 若要切割的位置已经超出数组范围,则添加该路径下的回文串

  • res:全部符合条件的回文串组合

  • paths:当前分割路径的回文串组合

if(startIndex > s.length()-1){
	res.add(new ArrayList(paths));
}
(3)遍历过程
for(int i=startIndex;i<s.length();i++){
	//判断当前段是否为回文
    if(isPalindrome(s,startIndex,i)){
        
        //获取 [startIndex,i]的子串
        String str=s.substring(startIndex,i+1);
        paths.add(str);
    }else{
        continue;
    }
    
    backing(s,i+1);
    
    //回溯
    paths.remove(paths.size()-1);
}
  • 判断是否为回文串方法:
private boolean isPalindrome(String s,int start,int end){
	for(;start<end;start++,end--){
        if(s.charAt(start)!=s.charAt(end)){
            return false;
        }
    }
    return true;
}

7.2.2代码

	List<List<String>> res=new ArrayList<>();
    List<String> paths=new ArrayList<>();

    public List<List<String>> partition(String s) {
        backing(s,0);
        return res;
    }

    private void backing(String s,int startIndex){
        if(startIndex>s.length()-1){
	        res.add(new ArrayList(paths));
            return;
        }  

        for(int i=startIndex;i<s.length();i++){
	        //判断当前段是否为回文
            if(isPalindrome(s,startIndex,i)){
        
                //获取 [startIndex,i]的子串
                String str=s.substring(startIndex,i+1);
                paths.add(str);
            }else{
                continue;
            }
    
            backing(s,i+1);
    
            //回溯
            paths.remove(paths.size()-1);
        }      
    }

    private boolean isPalindrome(String s,int start,int end){
	    for(;start<end;start++,end--){
            if(s.charAt(start)!=s.charAt(end)){
                return false;
            }
        }
        return true;
    }

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1599028.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

鸿蒙原生应用再新丁!企查查 碧蓝航线 入局鸿蒙

鸿蒙原生应用再新丁&#xff01;企查查 碧蓝航线 入局鸿蒙 来自 HarmonyOS 微博13日消息&#xff0c;碧蓝航线 将启动鸿蒙原生应用开发&#xff0c;双方将基于HarmonyOS NEXT鸿蒙星河版的原生流畅等特性&#xff0c;进一步提升游戏流畅度和画面精美度&#xff0c;为用户提供更…

汽车零部件制造迎来智能化升级,3D视觉定位系统助力无人化生产线建设

随着新能源汽车市场的蓬勃发展&#xff0c;汽车零部件制造行业正面临着前所未有的机遇与挑战。为了提高产能和产品加工精度&#xff0c;某专业铝合金汽车零部件制造商决定引进智能生产线&#xff0c;其中&#xff0c;对成垛摆放的变速箱壳体进行机床上料成为关键一环。 传统的上…

iframe嵌入海康威视摄像头监控视频画面

前言&#xff1a;海康威视有非常好的开放平台支持(海康开放平台)&#xff0c;如遇到技术问题&#xff0c;可以先花点时间在开放平台视频教程板块学习一下。直接问客服可能会比较懵&#xff0c;而且sdk客服和api客服互相分离&#xff0c;一开始可能都不知道问谁。 在开放平台上…

《二》Qt Creator工具介绍与使用

一、关于界面 点击文件--->新建文件或项目会出现如下图&#xff1a; 我们选择第一个 点击下一步下一步&#xff1a; 继续下一步直到结束&#xff1a; 二&#xff0c;具体文件介绍 我们点击pro查看以下 QT core gui第1行 表示使用qt的core和gui库&#xff0c;如果以后…

【JAVA基础篇教学】第十四篇:Java中设计模式

博主打算从0-1讲解下java基础教学&#xff0c;今天教学第十四篇&#xff1a;Java中设计模式。 设计模式是解决软件设计中常见问题的可重复利用的解决方案。在 Java 中&#xff0c;常见的设计模式包括单例模式、工厂模式、观察者模式等。目前在基础教学篇中只展示常见的几种模…

背会这套面试八股文!还怕拿不到offer吗?

给各位小伙伴总结了软件测试的高频面试题&#xff0c;其中包含了多个方面的知识点&#xff0c;包括&#xff1a; 测试基础(102页) Linux基础(38页) MySQL (63页) ️ web测试(28页) APP测试(38页) selenium相关(50页) 性能测试(55页) 数据结构跟算法(51页) 大厂逻辑题(…

图深度学习(一):介绍与概念

目录 一、介绍 二、图的数据结构 三、图深度学习的基本模型 四、图深度学习的基本操作和概念 五、训练过程 六、主要应用场景 七、总结 一、介绍 图深度学习是将深度学习应用于图形数据结构的领域&#xff0c;它结合了图论的概念和深度学习的技术&#xff0c;用以处理和…

二叉树的创建和遍历(java)

简介 二叉树是一种常见的树形数据结构&#xff0c;它由节点组成&#xff0c;每个节点最多有两个子节点&#xff0c;分别称为左子节点和右子节点。这些节点以层次结构的方式组织在一起&#xff0c;每个节点都有一个父节点&#xff0c;除了根节点外&#xff0c;每个节点都有一个…

SpringBoot配置profile

一、profile简介 我们在开发Spring Boot应用时&#xff0c;通常同一套程序会被安装到不同环境&#xff0c;比如:开发、测试、生产等。其中数据库地址、服务器端口等等配置都不同&#xff0c;如果每次打包时&#xff0c;都要修改配置文件&#xff0c;那么非常麻烦。profile功能就…

用Python做一个游戏辅助脚本,完整编程思路分享!

一、说明 简述&#xff1a;本文将以4399小游戏《 宠物连连看经典版2 》作为测试案例&#xff0c;通过识别小图标&#xff0c;模拟鼠标点击&#xff0c;快速完成配对。对于有兴趣学习游戏脚本的同学有一定的帮助。 运行环境&#xff1a;Win10/Python3.5。 主要模块&#xff1…

吴恩达llama课程笔记:第七课llama安全工具

羊驼Llama是当前最流行的开源大模型&#xff0c;其卓越的性能和广泛的应用领域使其成为业界瞩目的焦点。作为一款由Meta AI发布的开放且高效的大型基础语言模型&#xff0c;Llama拥有7B、13B和70B&#xff08;700亿&#xff09;三种版本&#xff0c;满足不同场景和需求。 吴恩…

C语言:文件操作(三)

目录 前言 5、文章的随机读写 5.1 fseek 5.2 ftell 5.3 rewind 结语 前言 本篇文章继续讲解文件操作&#xff0c;讲解文件的随机读写&#xff0c;主要有三个函数&#xff1a;fseek&#xff1b;ftell&#xff1b;rewind。 前面讲解的函数都是对文件内容进行顺序读写&#x…

STM32CubeMx下载安装环境搭建及工程创建

一、stm32介绍 STM32F103C8T6是一款由意法半导体公司&#xff08;ST&#xff09;推出的基于Cortex-M3内核的32位微控制器&#xff0c;硬件采用LQFP48封装&#xff0c;属于ST公司微控制器中的STM32系列。除了被我们熟知的STM32&#xff0c;ST公司还有SPC5X系列、STM8系列等&…

【C++类和对象】类和对象的引入

&#x1f49e;&#x1f49e; 前言 hello hello~ &#xff0c;这里是大耳朵土土垚~&#x1f496;&#x1f496; &#xff0c;欢迎大家点赞&#x1f973;&#x1f973;关注&#x1f4a5;&#x1f4a5;收藏&#x1f339;&#x1f339;&#x1f339; &#x1f4a5;个人主页&#x…

微信运动接口(获取自己的微信运动数据)

var pc new WXBizDataCrypt(appid, session_key); 这段代码是使用微信官方提供的 WXBizDataCrypt 类来解密微信运动数据。WXBizDataCrypt 是一个用于解密微信开放平台返回的加密数据的类&#xff0c;它需要传入两个参数&#xff1a;appid 和 session_key。其中&#xff0c;ap…

如何重置root用户的密码

即进入Linux操作系统的救援模式去重置密码。 1.首先重启机器&#xff0c; 2.进入grup菜单&#xff0c;按上下键盘&#xff0c;让系统的启动停在这个界面&#xff0c; 3.选择这个grup菜单的第一项&#xff0c;可以看界面下面的提示&#xff0c;按字母e编辑这个系统的启动配置…

STL —— stack、queue

博主首页&#xff1a; 有趣的中国人 专栏首页&#xff1a; C专栏 目录 1. 容器适配器 2. 栈的模拟实现 3. 队列的模拟实现 4. 双端队列deque 4.1 deque的原理介绍 4.2 deque的缺陷 4.3 为什么选择deque作为stack和queue的底层默认容器 本篇文章主要讲解 stack 和 queue …

基于SpringBoot的“银行OA系统的设计与实现”的设计与实现(源码+数据库+文档+PPT)

基于SpringBoot的“银行OA系统的设计与实现”的设计与实现&#xff08;源码数据库文档PPT) 开发语言&#xff1a;Java 数据库&#xff1a;MySQL 技术&#xff1a;SpringBoot 工具&#xff1a;IDEA/Ecilpse、Navicat、Maven 系统展示 用户登录界面 管理员主界面 员工基本档…

【C++从练气到飞升】07---内存管理

&#x1f388;个人主页&#xff1a;库库的里昂 ✨收录专栏&#xff1a;C从练气到飞升 &#x1f389;鸟欲高飞先振翅&#xff0c;人求上进先读书。 目录 一、 C/C内存分布 二、 C语言中动态内存管理方式 三、 C中动态内存管理 1. new/delete操作内置类型 2. new和delete操作…