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

LeetCode 5 最长回文子串

题目描述

最长回文子串

给你一个字符串 s,找到 s 中最长的回文子串。

如果字符串的反序与原始字符串相同,则该字符串称为回文字符串。

示例 1:

输入:s = "babad"
输出:"bab"
解释:"aba" 同样是符合题意的答案。

示例 2:

输入:s = "cbbd"
输出:"bb"

提示:

  • 1 <= s.length <= 1000
  • s 仅由数字和英文字母组成

解法

动态规划解法。

思路:

对于一个子串而言,如果它是回文串,并且长度大于 2,那么将它首尾的两个字母去除之后,它仍然是个回文串。

只有 s[i+1:j−1]是回文串,并且 s 的第 i 和 j 个字母相同时,s[i:j] 才会是回文串。

边界:1. 长度为 1 的子串,它是个回文串

	   2. 长度为 222 的子串,只要它的两个字母相同,它就是一个回文串

最终的答案即为所有 P(i,j)=true 中 j−i+1(即子串长度)的最大值

java代码:

class Solution {
    public String longestPalindrome(String s) {
        // 字符串长度小于2,直接返回长度(0或1)
        int len = s.length();
        if (len < 2) {
            return s;
        }

        // 初始化最长回文子串的长度为1
        int maxLen = 1;
        // 初始化最长回文子串的开始索引为0
        int begin = 1;
        // 维护子串是否是回文子串的状态列表,二维数组,分别是开始索引和结束索引
        boolean[][] dp = new boolean[len][len];
        // 初始化:所有长度为 1 的子串都是回文串
        for (int i = 0; i < len; i++) {
            dp[i][i] = true;
        }

        // 开始遍历,我们可以从第二个开始
        for (int i = 1; i < len; i++) {  // 子串右边界
            for (int j = 0; j < i; j++) {  // 子串左边界
                // 如果两个不相等,则一定不是回文子串
                if (s.charAt(i) != s.charAt(j)) {
                    dp[j][i] = false;
                } else {
                    // 如果两个相等
                    // 如果就两个元素,则是true
                    if (i - j < 3) {
                        dp[j][i] = true;
                    } else {
                        // 如果大于两个元素,则看他的子串是不是回文子串,子串是回文子串,他就是回文子串
                        dp[j][i] = dp[j + 1][i -1];
                    }
                }

                // 更新最大长度,如果当前子串是回文子串,并且长度大于前面的最大长度,就更新最大长度和起始索引
                if (dp[j][i] && (i - j + 1 > maxLen)) {
                    maxLen = i - j + 1;
                    begin = j;
                }
            }
        }
        return s.substring(begin, begin + maxLen);
    }
}

复杂度

时间复杂度:O(n^2),n为字符串长度。
空间复杂度:O(n^2),即存储动态规划状态需要的空间。


http://www.kler.cn/a/149785.html

相关文章:

  • 重新认识HTTPS
  • CSS 自定义滚动条样式
  • 设计模式——策略模式(c++)
  • Java-Redisson分布式锁+自定义注解+AOP的方式来实现后台防止重复请求扩展
  • 【Linux篇】面试——用户和组、文件类型、权限、进程
  • 《基于深度学习的车辆行驶三维环境双目感知方法研究》
  • Oracle Linux 9.3 发布
  • 大模型加载的参数介绍及推荐表,temperature、top_k、top_p、num_beams、num_beam_groups、do_sample等
  • Python压缩、解压文件
  • 数据库中生成列的对比
  • C 语言头文件
  • 图书管理系统源码,图书管理系统开发,图书借阅系统源码配置和运行图解源码已附加
  • 【华为OD题库-042】战场索敌-java
  • Kafka集群部署详细教程
  • Bug 检查 0x7B:INACCESSIBLE_BOOT_DEVICE(未解决)
  • Android WorldWind加载shapefile格式文件形成三维效果
  • Android 13.0 无源码app修改它的icon图标
  • 【pytest】执行环境切换的两种解决方案
  • IO和NIO的区别 BIO,NIO,AIO 有什么区别? Files的常用方法都有哪些?
  • 计算机端口
  • 量子力学应用:探索科技前沿的奇幻之旅
  • 智慧城市包括哪些内容?有哪些智慧城市物联网方案?
  • unity实时保存对象的位姿,重新运行程序时用最后保存的数据给物体赋值
  • UDP接收报文函数recvfrom和UDP发送报文函数sendto
  • runapi的学习记录
  • MySQL分页查询方法及优化