前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >☆打卡算法☆LeetCode 131. 分割回文串 算法解析

☆打卡算法☆LeetCode 131. 分割回文串 算法解析

作者头像
恬静的小魔龙
发布2022-08-07 10:33:54
1640
发布2022-08-07 10:33:54
举报
文章被收录于专栏:Unity3D
大家好,我是小魔龙,Unity3D软件工程师,VR、AR,虚拟仿真方向,不定时更新软件开发技巧,生活感悟,觉得有用记得一键三连哦。

一、题目

1、算法题目

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

题目链接:

来源:力扣(LeetCode)

链接: 131. 分割回文串 - 力扣(LeetCode) (leetcode-cn.com)

2、题目描述

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

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

代码语言:javascript
复制
示例 1:
输入: s = "aab"
输出: [["a","a","b"],["aa","b"]]
代码语言:javascript
复制
示例 2:
输入: s = "a"
输出: [["a"]]

二、解题

1、思路分析

题意要求找出字符串所有的分割方案,可以考虑使用回溯的方法遍历所有可能性进行判断。

递归树的模型是一颗二叉树,每一个节点表示剩余没有扫描到的字符串,产生分支是截取了剩余字符串的前缀:

  • 如果前缀字符串是回文,则可以产生分支和节点
  • 如果前缀字符串不是回文,则不产生分支和节点

然后从根节点到子节点的路径,就是结果集中的一个结果,使用深度优先遍历算法,记录所有可能的结果。

2、代码实现

代码参考:

代码语言:javascript
复制
class Solution {
    boolean[][] f;
    List<List<String>> ret = new ArrayList<List<String>>();
    List<String> ans = new ArrayList<String>();
    int n;

    public List<List<String>> partition(String s) {
        n = s.length();
        f = new boolean[n][n];
        for (int i = 0; i < n; ++i) {
            Arrays.fill(f[i], true);
        }

        for (int i = n - 1; i >= 0; --i) {
            for (int j = i + 1; j < n; ++j) {
                f[i][j] = (s.charAt(i) == s.charAt(j)) &amp;&amp; f[i + 1][j - 1];
            }
        }

        dfs(s, 0);
        return ret;
    }

    public void dfs(String s, int i) {
        if (i == n) {
            ret.add(new ArrayList<String>(ans));
            return;
        }
        for (int j = i; j < n; ++j) {
            if (f[i][j]) {
                ans.add(s.substring(i, j + 1));
                dfs(s, j + 1);
                ans.remove(ans.size() - 1);
            }
        }
    }
}
image.png
image.png

3、时间复杂度

时间复杂度:O(n · 2n)

其中n是字符串的长度。

空间复杂度:O(n2)

其中n是字符串的长度。

三、总结

在判断s[i,j]是否为回文串时,使用了两个指针分别指向i和j,每次判断两个指针指向的字符是否相同,直到两个指针相遇。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-04-25,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、题目
    • 1、算法题目
      • 2、题目描述
      • 二、解题
        • 1、思路分析
          • 2、代码实现
            • 3、时间复杂度
            • 三、总结
            领券
            问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档