C-最长回文子串(2)

时间:2022-03-09 01:43:12

在上一篇的文章中说到了,最长回文子串的问题,并且提到了基本的解决办法,即暴力求解法。效率O(N^3)

中心法求最长回文子串

我们知道回文字符串是以字符串中心对称的,如abba以及aba等。一个更好的办法是从中间开始判断,因为回文字符串以字符串中心对称。一个长度为N的字符串可能的对称中心有2N-1个,至于这里为什么是2N-1而不是N个,是因为可能对称的点可能是两个字符之间,比如abba的对称点就是第一个字母b和第二个字母b的中间。因此可以依次对2N-1个中心点进行判断,求出最长的回文字符串即可。

所以,要考虑回文是奇数还是偶数的情况。

#include<stdio.h>
#include<stdlib.h>
#include<ctype.h>
#define MAXN 500+10
char buf[MAXN],s[MAXN];
int index[MAXN]; int main()
{
int i,j;
int start = ,end = ;
int max = ;
int m = ,n;
fgets(buf,sizeof(s),stdin);
n = strlen(buf); //剔除其中的非字母字符,并且全部转换为大写字母
for(i = ;i<n;i++)
{
if(isalpha(buf[i]))
{
index[m] = i;
s[m++] = toupper(buf[i]);
}
}
for(i = ;i<m;i++)
{
/**奇数情况下*/
/**以i为中心,向左向右移动j,判断是否相同*/
/**这样求出的长度就是2*j+i*/
for(j = ;i+j<m && i-j>=;j++)
{
if(s[i-j] != s[j+i]) break;
if(*j+ > max)
{
max = *j+;
start = i-j;
end = i+j;
}
}
/**偶数情况下*/
/**以i 和 i+1为中心,左右移动j,再判断*/
for(j = ;i-j>= && i++j<m;j++)
{
if(s[i-j] != s[i++j]) break;
if(*j+ > max)
{
max = *j+;
start = i-j;
end = i+j+;
}
}
}
printf("max = %d\n",max);
for(i = index[start];i<=index[end];i++)
printf("%c",buf[i]);
putchar(); return ;
}

C-最长回文子串(2)的更多相关文章

  1. 最长回文子串-LeetCode 5 Longest Palindromic Substring

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

  2. 最长回文子串(Longest Palindromic Substring)

    这算是一道经典的题目了,最长回文子串问题是在一个字符串中求得满足回文子串条件的最长的那一个.常见的解题方法有三种: (1)暴力枚举法,以每个元素为中心同时向左和向右出发,复杂度O(n^2): (2)动 ...

  3. lintcode最长回文子串&lpar;Manacher算法&rpar;

    题目来自lintcode, 链接:http://www.lintcode.com/zh-cn/problem/longest-palindromic-substring/ 最长回文子串 给出一个字符串 ...

  4. 1089 最长回文子串 V2(Manacher算法)

    1089 最长回文子串 V2(Manacher算法) 基准时间限制:1 秒 空间限制:131072 KB 分值: 0 难度:基础题  收藏  关注 回文串是指aba.abba.cccbccc.aaaa ...

  5. 51nod1089&lpar;最长回文子串之manacher算法&rpar;

    题目链接: https://www.51nod.com/onlineJudge/questionCode.html#!problemId=1089 题意:中文题诶~ 思路: 我前面做的那道回文子串的题 ...

  6. 求最长回文子串:Manacher算法

    主要学习自:http://articles.leetcode.com/2011/11/longest-palindromic-substring-part-ii.html 问题描述:回文字符串就是左右 ...

  7. &lbrack;译&plus;改&rsqb;最长回文子串&lpar;Longest Palindromic Substring&rpar; Part II

    [译+改]最长回文子串(Longest Palindromic Substring) Part II 原文链接在http://leetcode.com/2011/11/longest-palindro ...

  8. &lbrack;译&rsqb;最长回文子串&lpar;Longest Palindromic Substring&rpar; Part I

    [译]最长回文子串(Longest Palindromic Substring) Part I 英文原文链接在(http://leetcode.com/2011/11/longest-palindro ...

  9. Manacher&&num;39&semi;s algorithm&colon; 最长回文子串算法

    Manacher 算法是时间.空间复杂度都为 O(n) 的解决 Longest palindromic substring(最长回文子串)的算法.回文串是中心对称的串,比如 'abcba'.'abcc ...

  10. 【转】最长回文子串的O&lpar;n&rpar;的Manacher算法

    Manacher算法 首先:大家都知道什么叫回文串吧,这个算法要解决的就是一个字符串中最长的回文子串有多长.这个算法可以在O(n)的时间复杂度内既线性时间复杂度的情况下,求出以每个字符为中心的最长回文 ...

随机推荐

  1. java:I&sol;O 一行一行读取和写入

    BufferedReader逐行读取 import java.io.*; class Test { public static void main(String args []){ FileReade ...

  2. python 面向对象简单理解

    面向对象: 是一种程序设计范型 作用: 提高软件的重用性和灵活性,扩展性 世界万物一切皆为对象,对象即是指由特定状态,特征,行为的实体   知识点一: 代码的重用 举个栗子 比如小月月有了一个女朋友1 ...

  3. JAVA程序&comma;SESSION没有关闭导致数据库异常

    可以看到连接到数据库的机器名为perass: PROCESS 1234表示是JDBC的进程 查询SQL: select username,         machine,         statu ...

  4. 一个关于导出excel模板的实例

    1 首先jsp页面 点击模板下载,会自动下载模板excel,效果如下 让我们看源码: 1 jsp页面 <div class="tab-pane" id="profi ...

  5. CSS 权威指南 CSS实战手册 第四版(阅读笔记)

    前言: 对于程序员,学习是无止境的,知识淘换非常快,能够快速稳固掌握一门新技术,是一个程序员应该具备的素质.这里将分析本人一点点不成熟的心得. 了解一门语言,了解它的概念非常重要,但是一些优秀的设计思 ...

  6. RabbitMQ在Windows环境下的安装与使用

    Windows下安装RabbitMQ 环境配置 部署环境 部署环境:windows server 2008 r2 enterprise 官方安装部署文档:http://www.rabbitmq.com ...

  7. Eclipse及Eclipse为基础的App报错&OpenCurlyDoubleQuote;Failed to create the Java Virtual Machine”的解决办法

    由于OracleJDK马上就要收费了,公司要求更换OpenJDK,结果安装后Eclipse及Eclipse为基础的App启动报错:“Failed to create the Java Virtual ...

  8. MT【227】换钱的总数

    (2012复旦)将1张面值100元的人民币全部换成面值1角,2角,5角的人民币,不同的换法有多少种? 解:即求不等式$2x+5y\le1000$的所有非负整数解的个数.由匹克公式:$S=a+\dfra ...

  9. 解决:&lbrack;DCC Fatal Error&rsqb; &ast;&ast;&period;dpk &colon; E2202 Required package &&num;39&semi;&ast;&ast;&ast;&&num;39&semi; not found

    //[DCC Fatal Error] **.dpk : E2202 Required package '***' not found 意思是:[DCC致命错误] *:e2202需包***没有发现 D ...

  10. 解决spring boot JavaMailSender部分收件人错误导致发送失败的问题

    使用spring boot通常使用spring-boot-starter-mail进行邮件的发送.当进行邮件群发的话,如果一个收件人的地址错误,会导致所有邮件都发送失败.因此我们需要在邮件发送失败的时 ...