【leetcode】131.分割回文串 (回溯法+优化,java实现)

该博客探讨了如何使用Java通过回溯法来解决LeetCode上的131题,即分割回文串问题。文章详细介绍了回溯法的思考过程和编码策略,并提供了两种解决方案:基本回溯法和优化后的回溯法,后者结合了动态规划以提高效率。在优化的回溯法中,通过预先计算最长回文子串来实现O(1)时间复杂度的回文验证。
摘要由CSDN通过智能技术生成
131. 分割回文串

难度中等

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

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

示例:

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

搜索问题主要使用回溯法。

回溯法思考的步骤:

1、画递归树;

2、根据自己画的递归树编码。

image.png

思考如何根据这棵递归树编码:

1、每一个结点表示剩余没有扫描到的字符串,产生分支是截取了剩余字符串的前缀;

2、产生前缀字符串的时候,判断前缀字符串是否是回文。

  • 如果前缀字符串是回文,则可以产生分支和结点;
  • 如果前缀字符串不是回文,则不产生分支和结点,这一步是剪枝操作。

3、在叶子结点是空字符串的时候结算,此时从根结点到叶子结点的路径,就是结果集里的一个结果,使用深度优先遍历,记录下所有可能的结果

  • 采用一个路径变量 path 搜索,path 全局使用一个(注意结算的时候,需要生成一个拷贝),因此在递归执行方法结束以后需要回溯,即将递归之前添加进来的元素拿出去;
  • path 的操作只在列表的末端,因此合适的数据结构是栈。

方法一:回溯

参考代码 1

  • Java
import java.util.ArrayDeque;
import java.util.ArrayList;
import java.util.Deque;
import java.util.List;

public class Solution {
   

    public List<List<String>> partition(String s) {
   
        int len = s.length();
        List<List<String>> res = new ArrayList<>();
        if (len == 0) {
   
            return res;
        }

        // Stack 这个类 Java 的文档里推荐写成 Deque<Integer> stack = new ArrayDeque<Integer>();
        // 注意:只使用 stack 相关的接口
        Deque<String> stack = new ArrayDeque<>();
        backtracking(s, 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值