输出最大长度的回文子串。

 string longestPalindrome(string s)
{ int id, mx, i, j, len, maxlen;
vector<char> cvec;
vector<int> ivec;
string str;
int ma, k; id = ;
mx = ;
ivec.push_back();
len = s.size();
maxlen = *s.size() + ; for (i = ; i < len; ++i)
{
cvec.push_back('#');
cvec.push_back(s[i]);
}
cvec.push_back('#'); for (i = ; i < maxlen; ++i)
{
if (mx > i)
{
int temp;
temp = ((mx - i - ) > (ivec[*id - i])) ? (ivec[*id - i]) : (mx - i - );
ivec.push_back(temp);
}
else
ivec.push_back(); for (; (i - ivec[i] >= ) && ((i + ivec[i]) < maxlen) && (cvec[i-ivec[i]] == cvec[i+ivec[i]]); ++ivec[i])
; if (mx < ivec[i] + i - )
{
mx = ivec[i] + i - ;
id = i;
}
} ma = ;
for (i = ; i < maxlen; ++i)
{
if (ivec[i] > ma)
{
ma = ivec[i];
k = i;
}
} for (j = , i = k - ivec[k] + ; j < ivec[k] - ; ++i, ++j)
{
++i;
str.push_back(cvec[i]);
} return str;
}

对于判断一个整数是否是回文,有另外的方法,不需要另外开辟空间。把地位当做高位,计算其值。

比如:123,计算3*100 + 2*10 + 1 的值是否与123相等。代码如下:

 void isPalindrome(int integer)
{
int temp, count, num, digit; if (integer < )
{
printf("不是回文整数\n");
return;
}
if (integer == )
{
printf("是回文整数\n");
return;
} temp = integer;
count = ;
while (temp)
{
count++;
temp = temp / ;
} temp = integer;
num = ;
while (temp > )
{
digit = temp - (temp / ) * ;
num = digit * int_pow(count) + num;
temp = temp / ;
count--;
} if (num == integer)
{
printf("是回文整数\n");
}
else
{
printf("不是回文整数\n");
} } int int_pow(int x)
{
int result = ; while (x > )
{
result = result * ;
x--;
}
return result;
}

最大长度回文子串(Manacher's algorithm)的更多相关文章

  1. 九度OJ 1528 最长回文子串 -- Manacher算法

    题目地址:http://ac.jobdu.com/problem.php?pid=1528 题目描述: 回文串就是一个正读和反读都一样的字符串,比如"level"或者"n ...

  2. 最长回文子串——manacher

    最长回文子串--Manacher 算法 (原版的博主的代码都是用py写的,这里改成c++) c++ 算法 字符串处理 0. 问题定义 最长回文子串问题:给定一个字符串,求它的最长回文子串长度. 如果一 ...

  3. hihocoder #1032 : 最长回文子串 Manacher算法

    题目链接: https://hihocoder.com/problemset/problem/1032?sid=868170 最长回文子串 时间限制:1000ms内存限制:64MB 问题描述 小Hi和 ...

  4. hihoCoder #1032 : 最长回文子串 [ Manacher算法--O(n)回文子串算法 ]

    传送门 #1032 : 最长回文子串 时间限制:1000ms 单点时限:1000ms 内存限制:64MB 描述 小Hi和小Ho是一对好朋友,出生在信息化社会的他们对编程产生了莫大的兴趣,他们约定好互相 ...

  5. 51nod1089 最长回文子串 manacher算法

    0. 问题定义 最长回文子串问题:给定一个字符串,求它的最长回文子串长度. 如果一个字符串正着读和反着读是一样的,那它就是回文串.下面是一些回文串的实例: 12321 a aba abba aaaa ...

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

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

  7. 最长回文子串Manacher算法模板

    Manacher算法能够在O(N)的时间复杂度内得到一个字符串以任意位置为中心的回文子串.其算法的基本原理就是利用已知回文串的左半部分来推导右半部分. 首先,在字符串s中,用rad[i]表示第i个字符 ...

  8. 最长回文子串—Manacher 算法 及 python实现

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

  9. Girls' research---hdu3294(回文子串manacher)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3294 给出一个字符串和加密的字符规律 例如 c abcba c代表把串中的c改成a,d改成b... b ...

随机推荐

  1. android基础复习

    http://www.cnblogs.com/aimeng/archive/2012/03/13/2393244.html android体系介绍 http://blog.chinaunix.net/ ...

  2. AES 加密 PHP 和 JAVA 互通

    PHP代码: <?php class Security { public static function encrypt($input, $key) { $size = mcrypt_get_b ...

  3. lca最近公共祖先(st表/倍增)

    大体思路 1.求出每个元素在树中的深度 2.用st表预处理的方法处理出f[i][j],f[i][j]表示元素i上方第2^j行对应的祖先是谁 3.将较深的点向上挪,直到两结点的深度相同 4.深度相同后, ...

  4. 一、接口测试——HTTPRunner二次开发之参数化一

    目前项目中在使用开源框架HTTPRunner,时间使用过程中会用到生成随机信息的方法,如生成随机姓名.随机手机号.身份证号.姓名.地址等.以下对二次开发的过程进行简要描述. 一.需求 1.需要测试的接 ...

  5. JDK动态代理 Proxy InvocationHandler

  6. Maven入门 项目的生命周期&pom.xml配置&仓库

  7. Centos 7 install cacti监控

    首先,先安装LNMP服务 安装一: 如果觉得安装起来麻烦,可以到如下网站进行安装: https://lnmp.org/install.html 安装二: 采用yum或者安装包的方式进行安装,具体操作请 ...

  8. 微信小程序实战

    为了积攒粉丝,公司决定做一个一分钱姓名测算的小程序引导大家关注公众号. 实现的需求就是  1 首页 用户编辑姓名和性别进行提交 2 测算结果页 实现分享和支付功能 3 测算历史页面 看到用户曾经测算记 ...

  9. The new week-学习Python-数据类型

    记录自学Python心得 之前有一段时间的JAVA自学,但最终以“无目标”的状态下被懒散驱散了动力,此为前提 Python的历程就不细细说道了,蛮有趣的 一般大家都是学习的CPython,速度较快(这 ...

  10. Hive_Hive的数据模型_分区表

    Hive的数据模型之分区表 准备数据表: create table sampledata (sid int, sname string, gender string, language int, ma ...