leetcode 05 回文字符串

1. 描述

给你一个字符串,找到里面最长的回文字符串

2. 事例

示例 1:

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

示例 2:

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

3. 思路

3.1 什么是回文字串

abba
abcba

我们把这种不管是从前到后读还是从后到前读都是一样的单词叫做回文字串

3.2 思路

3.2.1 dp数组

明确一个dp数组,即当前dp数组每个下标对应的含义

dp[i][j] 表示s的前i个字符到j个字符是否符合回文字串。
字符串 á b c b a
下标 0 1 2 3 4
i/j 0 1 2 3 4
0 True False False False True
1 True False True False
2 True False False
3 True False
4 True

3.2.2 怎么判断当前子串是回文字串。

$$

dp[i][j] = s[i] == s[j] and s[i+1][j-1] or j - 1 <= 2

$$

假设我现在有个字符串aba

当s[i]和s[j]等于当时候,我们就需要判断从i到j里面包含了几个字符。

比如当i = 0 j = 2当是时候,如果s[i] = s[j] 就只需要判断里面的元素是否大于1了,我们就可以得到一个公式。

$$

j - i <= 2

$$

如果这个公式成立的话,并且s[i] = s[j] 那么就是一个回文字串。

只需要判断s[i] == s[j] 并且 s[i + 1] [j - 1] 或者 j - i <= 2。

3.3.3 怎么取最大的回文字串。

我们上面知道了怎么判断字串是回文字串,我们就可以先定义一个left,并记录一个最大的长度。然后每次是回文字串的时候判断是否大于已经记录的,如果大于则就进行替换,如果小宇我们就跳过。

注意!!! 这里我们要注意下。

这里的最大长度应该好似j - i + 1.

3.3.4 代码编写

3.3.4.1 python
def longestPalindrome(s: str) -> str:
if len(s) <= 1:
return s
left = 0
maxLength = 1
dp = [[False for i in range(len(s))] for i in range(len(s))]
for j in range(1, len(s)):
for i in range(j):
if s[i] != s[j]:
continue
else:
dp[i][j] = dp[i + 1][j - 1] or j - i <= 2
if dp[i][j] and j - i + 1 > maxLength:
left = i
maxLength = j - i + 1
return s[left: left + maxLength]
3.3.4.2 typescript
onst longestPalindrome = (s: string): string => {
if (s.length <= 1) return s;
let left = 0, maxlength = 1;
const dp = new Array(s.length).fill(0).map(item => new Array(s.length).fill(false));
for (let j = 1; j < s.length; j++) {
for (let i = 0; i < j; i++) {
if (s[i] !== s[j]) continue;
dp[i][j] = dp[i + 1][j - 1] || j - i <= 2;
if (dp[i][j] && j - i + 1 > maxlength) {
maxlength = j - i + 1;
left = i;
}
}
}
return s.slice(left, left + maxlength)
}
java
 public static String longestPalindromeV2(String s) {
int left = 0;
int maxLength = 1;
boolean[][] dp = new boolean[s.length() + 1][s.length() + 1];
if (s.length() <= 1) return s;
for (int j = 1; j < s.length(); j++) {
for (int i = 0; i < j; i++) {
if (s.charAt(i) != s.charAt(j)) {
continue;
} else {
dp[i][j] = dp[i + 1][j - 1] || j - i <= 2;
}
if (dp[i][j] && j - i + 1 > maxLength) {
maxLength = j - i + 1;
left = i;
}
}
}
return s.substring(left, left + maxLength);
}

leetcode 05 回文字符串的更多相关文章

  1. [LeetCode] Valid Palindrome 验证回文字符串

    Given a string, determine if it is a palindrome, considering only alphanumeric characters and ignori ...

  2. leetcode:Longest Palindromic Substring(求最大的回文字符串)

    Question:Given a string S, find the longest palindromic substring in S. You may assume that the maxi ...

  3. leetcode 5 Longest Palindromic Substring--最长回文字符串

    问题描述 Given a string S, find the longest palindromic substring in S. You may assume that the maximum ...

  4. [LeetCode] 680. Valid Palindrome II 验证回文字符串 II

    Given a non-empty string s, you may delete at most one character. Judge whether you can make it a pa ...

  5. LeetCode 680. 验证回文字符串 Ⅱ(Valid Palindrome II) 1

    680. 验证回文字符串 Ⅱ 680. Valid Palindrome II 题目描述 给定一个非空字符串 s,最多删除一个字符.判断是否能成为回文字符串. 每日一算法2019/5/4Day 1Le ...

  6. 【LeetCode】1400. 构造 K 个回文字符串 Construct K Palindrome Strings

    作者: 负雪明烛 id: fuxuemingzhu 个人博客:http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 统计奇数字符出现次数 日期 题目地址:https:// ...

  7. 【LeetCode】680. Valid Palindrome II 验证回文字符串 Ⅱ(Python)

    作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 双指针 思路来源 初版方案 进阶方案 日期 题目地址 ...

  8. LeetCode 第五题 最长的回文字符串 (JAVA)

    Longest Palindromic Substring 简介:字符串中最长的回文字符串 回文字符串:中心对称的字符串 ,如 mom,noon 问题详解: 给定一个字符串s,寻找字符串中最长的回文字 ...

  9. Leetcode. 回文字符串的分割和最少分割数

    Q1: 回文字符串的分割 Given a string s, partition s such that every substring of the partition is a palindrom ...

  10. Leetcode 680.验证回文字符串

    验证回文字符串 给定一个非空字符串 s,最多删除一个字符.判断是否能成为回文字符串. 示例 1: 输入: "aba" 输出: True 示例 2: 输入: "abca&q ...

随机推荐

  1. work中模板、主题、样式集、样式的作用和使用方法

    [收藏]Word样式.样式集.主题.模版怎么区分?进来围观学习了~ 我们先来按照层次关系从小到大排序:样式<样式集<主题<模板 接下来,我们按照层次关系从小到大开始了解它们之间的的区 ...

  2. AI赋能-《用ChatGPT做软件测试》新书上市

    图书链接京东: https://item.jd.com/10121763192532.html当当: http://product.dangdang.com/29797547.html内容简介本书以目 ...

  3. spring注解@PostConstruct

    该注解可以实现在运行工程时,自动运行该注解下的方法: @PostConstruct是java5的时候引入的注解,指的是在项目启动的时候执行这个方法,也可以理解为在spring容器启动的时候执行,可作为 ...

  4. DFS序求LCA

    DFS序求LCA 介绍 欧拉序求LCA 的数组总是会忘记开两倍,并且预处理的常数较大.用 DFS序求LCA 可以解决这些问题. 欧拉序:进节点和出节点会重复记录节点. DFS序:深度优先搜索的顺序,不 ...

  5. win10启用长路径

    方法一:操作组策略 Win+R 输入 gpedit.msc 依次点击[计算机配置]->[管理模板]->[系统]->[文件系统],找到 "启用win32长路径" 并 ...

  6. delphi Image32 路径

    用 Image32的理由之一,也是路径这块做得比delphi(FMX)自带的要好,skia中支持svg,但对路径处理功能不够强大.VCL只能使用第三方库. VCL如果要支持SVG,只有 Image32 ...

  7. 2023NOIP A层联测32 T3 sakuya

    2023NOIP A层联测32 T3 sakuya 虚伪的期望,彬彬赛时都能 A 的数学题. 思路 考虑算出来总的花费,再除以 \(m!\) 求期望. 对于某个排列的花费为:\(\sum\limits ...

  8. 鸿蒙NEXT开发案例:简体繁体转换器

    [引言] 简体繁体转换器是一个实用的小工具,它可以帮助用户轻松地在简体中文和繁体中文之间进行转换.对于需要频繁处理两岸三地文档的用户来说,这样的工具无疑是提高工作效率的好帮手.本案例将展示如何利用鸿蒙 ...

  9. 子/次模 (Submodular)、超模 (Supermodular)和模(Modular)函数

    定义 子模 (Submodular).超模 (Supermodular)和模(Modular)函数是组合优化中用到的集合函数概念.函数定义域为某个有限集$\Omega$的幂集$2^\Omega$,值域 ...

  10. Linux中的用户管理-创建删除修改

    用户管理 一.用户分类 用户分为三类: 1.管理员 root root UID:0 #拥有最高权限 默认系统中就一个 UID即user ID 类似于身份号码,唯一的,不可重复 2.虚拟用户 作用:在运 ...