这一题我用的相对比较笨的方法。
相对于大佬们用的动态规划法,比较复杂。但却更容易理解,我主要是通过记录下标来确定最长回文串的。

package leetcode.day_12_06;

/**
* 给你一个字符串 s,找到 s 中最长的回文子串。
* <p>
* <p>
* 示例 1:
* <p>
* 输入:s = "babad"
* 输出:"bab"
* 解释:"aba" 同样是符合题意的答案。
* 示例 2:
* <p>
* 输入:s = "cbbd"
* 输出:"bb"
* 示例 3:
* <p>
* 输入:s = "a"
* 输出:"a"
* 示例 4:
* <p>
* 输入:s = "ac"
* 输出:"a"
*
* @author soberw
* @Classname LongestPalindrome0005
* @Description
* @Date 2021-12-06 12:39
*/
public class LongestPalindrome0005 {
/**
* @param s 需要查找的字符串
* @description: 找到 s 中最长的回文子串。
* @return: 最长回文子串
* @author: soberw
* @time: 2021/12/6 12:40
*/
public String longestPalindrome(String s) {
//直接返回
if (s.length() == 0 || s.length() == 1) {
return s;
}
int len = s.length();
//定义回文子串的起止下标
int start = 0;
int end = 0;
//定义两个指针(头尾)
int left = 0;
int right = 0;
for (int i = 0; i < len; i++) {
left = i;
right = i;
//从当前位置开始,判断尾指针后面的字符是否与当前所指相等,相等继续向后比较
//旨在找到连续字符
while (right < len - 1 && s.charAt(right) == s.charAt(right + 1)) {
right++;
}
//在连续字符的基础上,判断其前一个是否和后一个相等,以此类推
while (left > 0 && right < len - 1 && s.charAt(left - 1) == s.charAt(right + 1)) {
left--;
right++;
}
//始终保持start和end是最大的范围
if ((end - start) < (right - left)) {
start = left;
end = right;
}
}
return s.substring(start, end + 1);
} public static void main(String[] args) {
System.out.println(new LongestPalindrome0005().longestPalindrome("babad"));
System.out.println(new LongestPalindrome0005().longestPalindrome("cbbd"));
System.out.println(new LongestPalindrome0005().longestPalindrome(""));
System.out.println(new LongestPalindrome0005().longestPalindrome("a"));
}
}

运行结果:


可能上面的解释还比较笼统,下面我画图演示一下执行流程:
例一:输入"bbbbb”:

刚开始left=0,right=0
程序进入第一个while循环,且满足条件,因为s[0]=s[1]=“b”,所以right++
向后走发现继续相等,就一直向后,直到不满足条件退出
此时right = len - 1
不满足第二个循环条件(其实就是right走到头了)

就这样进行下去,保证(end - start)始终是最长的,最后只需要截取就行了

例二:输入“babc”

刚开始left=0,right=0 程序进入第一个while循环,不满足条件,即“b” != “a”,进入第二个循环(不满足条件直接退出)

第二遍,此时left=right=1,不满足第一个循环,进入第二个,发现s[left - 1] = s[right + 1],于是继续循环。此时left=0,退出

就这样进行下去,保证(end - start)始终是最长的,最后start=0,end=2
截取为“bab”

简而言之:

整个代码的结果就是从左到右遍历,无连续相同的就以当前字符向两侧遍历看是否相等,有则从连续字符两侧遍历

LeetCode随缘刷题之最长回文子串的更多相关文章

  1. leetcode刷题五<最长回文子串>

    下面是题目的描述 给定一个字符串 s,找到 s 中最长的回文子串.你可以假设 s 的最大长度为 . 示例 : 输入: "babad" 输出: "bab" 注意: ...

  2. LeetCode刷题-005最长回文子串

    给定一个字符串 s,找到 s 中最长的回文子串.你可以假设 s 的最大长度为1000.示例 1:输入: "babad"输出: "bab"注意: "ab ...

  3. Leetcode 5. Longest Palindromic Substring(最长回文子串, Manacher算法)

    Leetcode 5. Longest Palindromic Substring(最长回文子串, Manacher算法) Given a string s, find the longest pal ...

  4. LeetCode(5):最长回文子串

    Medium! 题目描述: 给定一个字符串 s,找到 s 中最长的回文子串.你可以假设 s 长度最长为1000. 示例: 输入: "babad" 输出: "bab&quo ...

  5. [LeetCode] 5. Longest Palindromic Substring 最长回文子串

    Given a string s, find the longest palindromic substring in s. You may assume that the maximum lengt ...

  6. leetcode 求一个字符串的最长回文子串

    最长回文子串问题:给定一个字符串,求它的最长回文子串长度.如果一个字符串正着读和反着读是一样的,那它就是回文串.   给定一个字符串,求它最长的回文子串长度,例如输入字符串'35534321',它的最 ...

  7. [leetcode]5. Longest Palindromic Substring最长回文子串

    Given a string s, find the longest palindromic substring in s. You may assume that the maximum lengt ...

  8. leecode第五题(最长回文子串)

    class Solution { public: string longestPalindrome(string s) { int len = s.length(); || len == ) retu ...

  9. C#LeetCode刷题之#409-最长回文串(Longest Palindrome)

    问题 该文章的最新版本已迁移至个人博客[比特飞],单击链接 https://www.byteflying.com/archives/3788 访问. 给定一个包含大写字母和小写字母的字符串,找到通过这 ...

随机推荐

  1. 『无为则无心』Python函数 — 29、Python变量和参数传递

    目录 1.Python的变量 (1)Python变量不能独立存在 (2)变量是内存中数据的引用 (3)注意点 2.了解变量的引用 3.Python的参数传递(重点) (1)示例 (2)结论 (3)总结 ...

  2. Spring 处理请求和响应相关的注解

    @Controller 默认返回 templates 目录下的 string.html 页面内容. 在方法中加上 @ResponseBody 注解,可以返回JSON.XML或自定义mediaType的 ...

  3. Pytest_简介与安装(1)

    一.Pytest简介 pytest是python的一种单元测试框架,与python自带的unittest测试框架类似,但更灵活.官方网站优点简介: 非常容易上手,入门简单,文档丰富,文档中有很多实例可 ...

  4. nginxWebUI

    nginx网页配置工具 github: https://github.com/cym1102/nginxWebUI 功能说明 本项目可以使用WebUI配置nginx的各项功能, 包括http协议转发, ...

  5. ':app@debug/compileClasspath': Could not find any version that matches com.android.support:appcompat-v7:30.+.

    ERROR: Unable to resolve dependency for ':app@debug/compileClasspath': Could not find any version th ...

  6. Centos7 暂时记录

    chown 修改属主和属组信息 chown -R 对目录所有子的子目录和文件进行修改属主信息 w命令 USER TTY FROM    LOGIN@ IDLE JCPU PCPU WHATroot   ...

  7. PPT制作手机滑动粗糙效果

    原文链接:https://www.toutiao.com/i6495291974680052238/ 选择"插入"选项卡,"插图"功能组."形状&qu ...

  8. Enumy:一款功能强大的Linux后渗透提权枚举工具

    Enumy是一款功能强大的Linux后渗透提权枚举工具,该工具是一个速度非常快的可移植可执行文件,广大研究人员可以在针对Linux设备的渗透测试以及CTF的后渗透阶段利用该工具实现权限提升,而Enum ...

  9. golang中的定时器

    1.  timer 定时器,时间到了执行,只执行一次 package main import ( "fmt" "time" ) func main() { // ...

  10. 多线程-守护线程-setDaemon

    1 package multithread4; 2 /* 3 * 停止线程: 4 * 1,stop方法. 5 * 6 * 2,run方法结束. 7 * 8 * 怎么控制线程的任务结束呢? 9 * 任务 ...