九度题目1528:最长回文子串

题目1528:最长回文子串
时间限制:1 秒
内存限制:128 兆
特殊判题:否
提交:781
解决:239
题目描述:
回文串就是一个正读和反读都一样的字符串,比如“level”或者“noon”等等就是回文串。
回文子串,顾名思义,即字符串中满足回文性质的子串。
给出一个只由小写英文字符a,b,c...x,y,z组成的字符串,请输出其中最长的回文子串的长度。

输入:
输入包含多个测试用例,每组测试用例输入一行由小写英文字符a,b,c...x,y,z组成的字符串,字符串的长度不大于200000。

输出:
对于每组测试用例,输出一个整数,表示该组测试用例的字符串中所包含的的最长回文子串的长度。

样例输入:
abab
bbbb
abba

样例输出:
3
4
4

来源:
腾讯2013年实习生招聘二面面试题

 

有多种方法去求最长回文字串:

1.方法一:
中心求解法,从中间向两边检测,不断更新最长回文字符串大小,注意,可以分中心有一个字符的回文(奇数回文),如cabac,也有偶数的回文,如aabbaa,这要求我们要从中心或中心对称的两边字符往两边检测
AC代码:

#include<stdio.h>
#include<string.h>
char a[200010];
int FromeCenter(int l,int r,int n)//检测l至r之间的字符串中最长的回文字符串
{
     while(l>=0&&r<=n-1&&a[l]==a[r])
     {
        l--;r++;
     }
     return ((r-1)-(l+1)+1);
}
int main()
{
    int i,j,n,m,max,p1,p2;
    while(scanf("%s",a)!=EOF)
    {
       n=strlen(a);
       max=0;
       for(i=0;i<n;i++)
       {
          p1=FromeCenter(i,i,n);//以位置i为中心的最长回文字符串
          if(p1>max)
          max=p1;

          p2=FromeCenter(i,i+1,n);//以i和i+1之间的位置为中心的最长回文字符串
          if(p2>max)
          max=p2;
       }
       printf("%d\n",max);
       memset(a,0,sizeof(a));
    }
    return 0;
}

 

2.方法二,暴力求解法,只要从每个字符串开始向后检测,直至字符串的最后一个元素,检测每一个区间是否是回文字符串,更新最长的回文字符串长度;

代码(很不幸,因为长度为200000,所以华丽丽的超时了):

#include<stdio.h>
#include<string.h>
char a[200010];
int isPalinddrome(int l,int r,int n)
{
     while(l<r)
     {
        if(a[l]!=a[r])
        return 0;
        ++l;r--;
     }
     return 1;
}
int main()
{
    int i,j,n,m,max,p;
    while(scanf("%s",a)!=EOF)
    {
       n=strlen(a);
       max=0;
       for(i=0;i<n;i++)
       {
          for(j=i;j<n;j++)
          {
             if(isPalinddrome(i,j,n))
             {
                p=j-i+1;
                if(p>max)
                max=p;
             }
          }
       }
       printf("%d\n",max);
       memset(a,0,sizeof(a));
    }
    return 0;
}

3.方法三,动态规划法
如果aba是回文,那么cabac也是回文,于是我们得到一个递推的公式:
假设s[i,j]是回文字符串的话,定义p[i,j]=1;
于是p[i,j]=1是由(p[i+1,j-1]&&s[i]==s[j])递推出来的,如此往后,直到p[i,i+1]=1,此时满足s[i]=s[i+1],最后p[i,i]=1;

这个暂时,没有写出来.....

 

时间: 2024-08-01 18:48:05

九度题目1528:最长回文子串的相关文章

Longest Palindromic Substring:最长回文子串

题目链接 Given a string S, find the longest palindromic substring in S. You may assume that the maximum length of S is 1000, and there exists one unique longest palindromic substring. 求字符串的最长回文子串 算法1:暴力解法,枚举所有子串,对每个子串判断是否为回文,复杂度为O(n^3) 算法2:删除暴力解法中有很多重复的判

lintcode最长回文子串(Manacher算法)

题目来自lintcode, 链接:http://www.lintcode.com/zh-cn/problem/longest-palindromic-substring/ v最长回文子串  给出一个字符串(假设长度最长为1000),求出它的最长回文子串,你可以假定只有一个满足条件的最长回文串. v样例 给出字符串 "abcdzdcab",它的最长回文子串为 "cdzdc". v挑战 O(n2) 时间复杂度的算法是可以接受的,如果你能用 O(n) 的算法那自然更好.

最长公共子序列|最长公共子串|最长重复子串|最长不重复子串|最长回文子串|最长递增子序列|最大子数组和

参考:http://www.ahathinking.com/archives/124.html 最长公共子序列 1.动态规划解决过程 1)描述一个最长公共子序列 如果序列比较短,可以采用蛮力法枚举出X的所有子序列,然后检查是否是Y的子序列,并记录所发现的最长子序列.如果序列比较长,这种方法需要指数级时间,不切实际. LCS的最优子结构定理:设X={x1,x2,--,xm}和Y={y1,y2,--,yn}为两个序列,并设Z={z1.z2.--,zk}为X和Y的任意一个LCS,则:       (1

java算法-java求教,算法竞赛入门经典 3.4 最长回文子串

问题描述 java求教,算法竞赛入门经典 3.4 最长回文子串 java新手求教,关键是怎么保存s[i]在buf中的位置,谢谢 解决方案 string longestPalindromeDP(string s) { int n = s.length(); int longestBegin = 0; int maxLen = 1; bool table[1000][1000] = {false}; for (int i = 0; i < n; i++) { table[i][i] = true;

java算法-Longest Palindromic Substring 最长回文子串问题?JAVA

问题描述 Longest Palindromic Substring 最长回文子串问题?JAVA public class Solution { public String longestPalindrome(String s) { String ret = ""; for (int i = 0; i < s.length(); i++) { for (int j = 0; i - j >= 0 && i + j < s.length(); j++)

hihocoder 算法-我的hihocoder这个最长回文子串为什么报wrong answer?

问题描述 我的hihocoder这个最长回文子串为什么报wrong answer? import java.util.Scanner; public class Main { public static void main(String[] args) { Scanner scanner = new Scanner(System.in); int n = scanner.nextInt(); for(int i = 0;i String str = scanner.next(); System.

NYOJ 132(最长回文子串)

#include<stdio.h> #include<string.h> #include<ctype.h> #define MAXN 5001 char buf[MAXN],s[MAXN]; int p[MAXN]; int main() { int T,i,j;int len,m,max,x,y; scanf("%d%*c",&T); while(T--) { //fgets(buf,sizeof(buf),stdin); scanf(&

[算法系列之七]Manacher算法之最大回文子串

回文串定义:"回文串"是一个正读和反读都一样的字符串,比如"level"或者"noon"等等就是回文串. 回文子串,顾名思义,即字符串中满足回文性质的子串. 经常有一些题目围绕回文子串进行讨论,比如  HDOJ_3068_最长回文,求最长回文子串的长度.朴素算法是依次以每一个字符为中心向两侧进行扩展, 显然这个复杂度是 O(N^2)的,关于字符串的题目常用的算法有 KMP.后缀数组. AC 自动机,这道题目利用扩展 KMP可以解答,其时间复杂度也

[百度]2014百度校园招聘之最长回文串

[题目] 给你一个字符串,找出该字符串中对称的子字符串的最大长度.即求最大回文串. [思路1]暴力法 即不使用技巧,穷举所有可能.时间复杂度为O(n^3)(时间上最长,不推荐使用),空间复杂度为O(1). 本思路是从最大长度的字串开始,而不是从最小开始.假如说给定的字符串为len,先遍历长度为len的字串是否为回文串,如果是停止, 如果不是遍历长度为len-1的字串是否是回文串,一次类推. #include <iostream> using namespace std; //是否是回文串 bo