LeetCode随缘刷题之最长回文子串
这一题我用的相对比较笨的方法。
相对于大佬们用的动态规划法,比较复杂。但却更容易理解,我主要是通过记录下标来确定最长回文串的。
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随缘刷题之最长回文子串的更多相关文章
- leetcode刷题五<最长回文子串>
下面是题目的描述 给定一个字符串 s,找到 s 中最长的回文子串.你可以假设 s 的最大长度为 . 示例 : 输入: "babad" 输出: "bab" 注意: ...
- LeetCode刷题-005最长回文子串
给定一个字符串 s,找到 s 中最长的回文子串.你可以假设 s 的最大长度为1000.示例 1:输入: "babad"输出: "bab"注意: "ab ...
- Leetcode 5. Longest Palindromic Substring(最长回文子串, Manacher算法)
Leetcode 5. Longest Palindromic Substring(最长回文子串, Manacher算法) Given a string s, find the longest pal ...
- LeetCode(5):最长回文子串
Medium! 题目描述: 给定一个字符串 s,找到 s 中最长的回文子串.你可以假设 s 长度最长为1000. 示例: 输入: "babad" 输出: "bab&quo ...
- [LeetCode] 5. Longest Palindromic Substring 最长回文子串
Given a string s, find the longest palindromic substring in s. You may assume that the maximum lengt ...
- leetcode 求一个字符串的最长回文子串
最长回文子串问题:给定一个字符串,求它的最长回文子串长度.如果一个字符串正着读和反着读是一样的,那它就是回文串. 给定一个字符串,求它最长的回文子串长度,例如输入字符串'35534321',它的最 ...
- [leetcode]5. Longest Palindromic Substring最长回文子串
Given a string s, find the longest palindromic substring in s. You may assume that the maximum lengt ...
- leecode第五题(最长回文子串)
class Solution { public: string longestPalindrome(string s) { int len = s.length(); || len == ) retu ...
- C#LeetCode刷题之#409-最长回文串(Longest Palindrome)
问题 该文章的最新版本已迁移至个人博客[比特飞],单击链接 https://www.byteflying.com/archives/3788 访问. 给定一个包含大写字母和小写字母的字符串,找到通过这 ...
随机推荐
- 什么是LTV,舔狗的LTV可以乘以N吗?
依旧注意一下,数据类文章比较敏感,舔狗只是代词,千万不要以为我是舔狗. 之前我们探讨过如何对自己的用户进行分层:不知怎么选,用RFM模型看舔狗质量! 也探讨了如何判断自己适不适合海后(主播)这个业务: ...
- python appium使用uiselector定位时,提示 Could not parse UiSelector argument: 'XXX' is not a string
运行自动化代码,appium返回Could not parse UiSelector argument: 'XXX' is not a string,其中的xxx就是定位的元素 解决方案:外侧用 '' ...
- VMware_win10能ping通虚拟机ip,虚拟机ping不通win10ip的解决方法
一.虚拟机设置为桥接模式 二.修改虚拟机linux的ip 查看win10的ip和网关 使用ifconfig查看网卡名,并在 /etc/sysconfig/network-scripts/目录修改对应的 ...
- RabbitMQ 消息中间件 的下载与安装【window10】
1.前言 弄了好久,才终于把 rabbitmq装好 ,本来是很简单的,但是,安装有个要求就是路径不能有中文字符, 虽然可以安装,但是无法运行,需要修改路径名为非中文字符后重装rabbitmq才可以运行 ...
- vue 图片拖拽和滚轮缩放
这里注意如果自己的页面有滚动条,一定阻止滚动事件的默认行为,否则缩放图片的时候,页面会跟着滚动@mousewheel.prevent 阻止默认行为 <div ref="imgWrap& ...
- c++智能指针的使用,shared_ptr,unique_ptr,weak_ptr
c++智能指针的使用 官方参考 普通指针的烦恼:内存泄漏,多次释放,提前释放 智能指针 负责自动释放所指向的对象. 三种智能指针 shared_ptr,unique_ptr,weak_ptr: 将sh ...
- CSS3 动画3D视角下 旋转圆环
首先是 transform 属性: transform 属性向元素应用 2D 或 3D 转换.该属性允许我们对元素进行旋转.缩放.移动或倾斜. 加上对应属性则可得到3D透视效果下的形态 本次以圆形( ...
- 通过HTML+CSS+Javascript实现向下滚动滚动条出现导航栏并出现回到顶部按钮点击按钮回到顶部(一)
回到顶部实例一 效果:默认隐藏导航栏,当滚动条滚到超过300px后导航栏和按钮出现,点击回到顶部按钮回到顶部,并隐藏导航栏和按钮(导航栏和按钮都是固定定位) <!doctype html> ...
- How to mount Windows network disk in WSL
Backgroud Mount samba directly in wsl like linux is difficult Password for root@//filesystem.domain/ ...
- javascript 获取<td>标签内的值。
当网页被加载时,浏览器会创建页面的文档对象模型(Document Object Model). HTML DOM 模型被构造为对象的树. 通过可编程的对象模型,JavaScript 获得了足够的能力来 ...