leetcode-5最长回文子串(manacher算法)

leetcode-5最长回文子串(manacher算法)原题链接给你一个字符串 s,找到 s 中最长的回文子串。示例 1:输入:s = “babad”输出:”bab”解释:”aba” 同样是符合题意的答案。示例 2:输入:s = “cbbd”输出:”bb”示例 3:输入:s = “a”输出:”a”示例 4:输入:s = “ac”输出:”a” 提示:1 <= s.length <= 1000s 仅由数字和英文字母(大写和/或小写)组成题解暴力class Solution {public:

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

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

示例 1:

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

输入:s = "cbbd"
输出:"bb"
示例 3:

输入:s = "a"
输出:"a"
示例 4:

输入:s = "ac"
输出:"a"
 

提示:

1 <= s.length <= 1000
s 仅由数字和英文字母(大写和/或小写)组成

题解

  1. 遍历所有节点
class Solution { 
   
public:
    string longestPalindrome(string s) { 
   
        int res = 0,len = 1,l = 0,r = 0;
        for(int i = 0;i < s.size();i ++){ 
   
            len = 0;
            while(i - len >= 0 && i + len < s.size() && s[i - len] == s[i + len])len ++;
            if(len * 2 - 1 > res)res = len * 2 - 1,l = i - len + 1,r = i + len - 1;
        }
        for(int i = 0;i < s.size() - 1;i ++){ 
   
            int ll = i,rr = i + 1;
            while(ll >= 0 && rr < s.size() && s[ll] == s[rr])ll --,rr ++;
            if(rr - ll - 1 > res)res = rr - ll - 1,l = ll + 1,r = rr - 1;
        }
    
        return s.substr(l,r - l + 1);
    }
};
  1. manacher算法
class Solution { 
   
public:
    string longestPalindrome(string s) { 
   
        string t;
        t.append(1,'#');
        for(int i = 0;i < s.size();i ++){ 
   
            t.append(1,s[i]);
            t.append(1,'#');
        }
        cout<<t<<endl;
        vector<int>r(t.size());
        r[0] = 1;
        int res = 0;
        for(int i = 0,center = 0;i < t.size();i ++){ 
   
            if(center + r[center] < i){ 
   
                while(i + r[i] < t.size() && i - r[i] >= 0 && t[i + r[i]] == t[i - r[i]])r[i] ++;
                r[i] --;
            }
            else{ 
   
                int m = center - (i - center);
                if(m - r[m] > center - r[center])r[i] = r[m];
                else { 
   
                    r[i] = center + r[center] - i;
                    while(i + r[i] < t.size() && i - r[i] >= 0 && t[i - r[i]] == t[i + r[i]])r[i] ++;
                    r[i] --;
                }
            }
            if(r[i] > r[res])res = i;
            if(i + r[i] >= center + r[center])center = i;
            cout<<i<<" "<<r[i]<<endl;
        }
        cout<<res<<" "<<r[res]<<endl;
        string a;
        for(int i = res - r[res];i <= res + r[res];i ++){ 
   
            if(t[i] != '#')a.append(1,t[i]);
        }
        return a;
    }
};
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/168733.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • OpenCV对图像遍历的高效方法

    OpenCV对图像遍历的高效方法一、指针遍历首先介绍几个Mat类型的属性,rows是Mat类型的行数,cols是列数,channels()是通道数,那么对于图像的每一行,都有cols*channels()个像素点,所以我们可以对所有行进行遍历,然后对于特定一行,遍历所有像素点,代码如下:intnl=image.rows;//行数//每行的元素数量intnc=image.cols*i…

    2022年5月30日
    26
  • 搜狐视频P2P技术揭秘 – 流程篇

    搜狐视频P2P技术揭秘 – 流程篇本文介绍了搜狐视频P2P技术的整体业务流程,包括服务的调用,打洞等,比较详细。

    2022年6月19日
    28
  • 围观!一套开源车牌识别系统(附项目地址)

    围观!一套开源车牌识别系统(附项目地址)

    2020年11月13日
    245
  • Java入门代码_java编程自学网

    Java入门代码_java编程自学网首先在配置好java环境的前提下,安装好eclipse,以下示例均在eclipse下运行,代码详解看注释一、HelloWorld示例代码:packagecom.hpe.java;//这是一个问好程序publicclassHello{//一个类只能有一个main方法publicstaticvoidmain(Stringarg[]){System.out.print(“hellowo…

    2022年10月17日
    2
  • byte类型数据

    byte类型数据今儿一个小朋友问我一件事情 Java 的 byte 类型的数据范围是从 128 到 127 一直在想为什么不是 128 到 128 呢 首先我们得明白一件事情 那就是运算规则 正数的最高位都是 0 正数的值就是二进制表示的值 nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp nbsp 负数的最高位都是 1 负数的值是取反后加一然后加个负号得到得值 nbsp nbsp nbsp nbsp nbsp nbsp

    2025年9月28日
    3
  • 毕业五年

    好久不见,一年一度的“毕业N年”系列,2020,毕业五年了,今年来的略晚一些。五年是个挺重要的节点,所以今年不只是第五年,也是对自己前五年的复盘和总结。工作1、机会:能力很重要,机会最重要珍惜工作中脱颖而出的机会,不要轻易跳槽,要跳,一定是因为看到更好的机会。从我的经历来讲,毕业五年,加上实习已经工作了六年时间,百度(深圳)->百度(北京)->Finger(杭州)->阿里(杭州),一共换了四个团队,但都是个人原因,而不是因为更好的机会。这就导致换了几个队伍,好位置早已经有人,只能

    2022年3月11日
    46

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号