华为机试—最长回文子串

输入一个字符串,输出最长回文子串。当最长回文子串不止一个时,全部输出。

#include <iostream>
#include <string>
using namespace std;

#define N 100

string convert(string s)
{
	string out="";
    int len=s.length();
	for (int i=len-1;i>=0;i--)
	{
         out.insert(out.length(),1,s[i]);
	}
	return out;
}

void process(string r)
{
	int len=r.length();
	string *str = new string[N];
	for (int i=0;i<N;i++)
	{
		str[i]="\0";
	}
	int m=0;
	for (i=0;i<len;i++)
	{
		for (int j=len-1;j>=(i+1);j--)
		{
             if (r.substr(i,j-i+1)==convert(r.substr(i,j-i+1)))
             {
                 str[m++]=r.substr(i,j-i+1);
             }
		}
	}

	for(int k=0;k<m;k++)
		cout<<str[k]<<endl;
	cout<<endl;

	int maxlen=str[0].length();
	for(k=1;k<m;k++)
		if(maxlen<str[k].length())
			maxlen=str[k].length();

	for(k=0;k<m;k++)
		if(maxlen==str[k].length())
			cout<<str[k]<<endl;
}

void main()
{
	string in;
    getline(cin,in);
	process(in);
}

测试结果,可能想的不周全,欢迎查漏补缺:

时间: 2024-08-03 00:44:25

华为机试—最长回文子串的相关文章

求最长回文子串,O(n)复杂度

最长回文子串问题-Manacher算法 最长回文串问题是一个经典的算法题. 0. 问题定义 最长回文子串问题:给定一个字符串,求它的最长回文子串长度. 如果一个字符串正着读和反着读是一样的,那它就是回文串.下面是一些回文串的实例: 12321 a aba abba aaaa tattarrattat(牛津英语词典中最长的回文单词) 1. Brute-force解法 对于最长回文子串问题,最简单粗暴的办法是:找到字符串的所有子串,遍历每一个子串以验证它们是否为回文串.一个子串由子串的起点和终点确定

最长回文子串问题—Manacher算法

Manacher 算法(http://www.jianshu.com/p/799bc53d4e3d) 对于一个比较长的字符串,O(n^2)的时间复杂度是难以接受的.Can we do better?先来看看解法2存在的缺陷. 1)由于回文串长度的奇偶性造成了不同性质的对称轴位置,解法2要对两种情况分别处理: 2)很多子串被重复多次访问,造成较差的时间效率. 缺陷2)可以通过这个直观的小??体现: char: a b a b a i : 0 1 2 3 4 当i==1,和i==2时,左边的子串ab

manacherO(n)求最长回文子串 hihocoder1032

原文地址:https://segmentfault.com/a/1190000003914228   http://blog.csdn.net/synapse7/article/details/18908413 灰常不错的学习资料 先预处理下:在每个字符的两边都插入一个特殊的符号,比如abba变成#a#b#b#a#,aba变成 #a#b#a#(因为Manacher算法只能处理奇数长度的字符串).同时,为了避免数组越界,在字符串开头添加另一特殊符号,比如$#a#b#a#. 以字符串32123432

《算法竞赛入门经典》3.3最长回文子串

1 //例题3-4 2 /* 3 * 输入一个字符串,求出其中最长的回文子串.子串的含义是:在原串中连续出现的字符串片段. 4 *回文的含义是:正看着和倒看着相同,如abba和yyxyy.在判断时,应该忽略所有标点符号和空格 5 *且忽略大小写,但输出应保持原样(在回文串的首部和尾部不要输出多余字符).输入字符长度不超过5000 6 *且占据单独的一行.应该输出最长回文串,如果有多个,输出起始位置最靠左的. 7 *样例输入:Confuciuss say:Madam,I'm Adam. 8 *样例

Manacher算法----最长回文子串

题目描述 给定一个字符串,求它的最长回文子串的长度. 分析与解法 最容易想到的办法是枚举所有的子串,分别判断其是否为回文.这个思路初看起来是正确的,但却做了很多无用功,如果一个长的子串包含另一个短一些的子串,那么对子串的回文判断其实是不需要的.同时,奇数和偶数长度还要分别考虑. Manacher算法可以解决上述问题,并在O(n)时间复杂度内求出结果.下面我们来看一下Manacher算法. 首先,为了处理奇偶的问题,在每个字符的两边都插入一个特殊的符号,这样所有的奇数或偶数长度都转换为奇数长度.比

hihocoder1302 最长回文子串

hihocoder1302 最长回文子串 先贴代码 所有的上面的提示已经交代的好清楚了…… #include <iostream> #include <cstring> #include <cstdio> #include <cmath> #include <algorithm> #include <vector> #include <map> #include <queue> #include <sta

[hiho 01]最长回文子串、Manacher算法

题目描述 - 基础方法:枚举子串,判断是否为回文串. - 改进:枚举中间位置,向两侧拓展. - 再改进:利用以前的信息,使得不用每个新位置都从长度1开始拓展. - 优化:将字符串预处理为奇数长度以避免考虑条件分支. - 再优化:开头加入特殊字符避免考虑边界. Manacher 算法: id 是中心点,mx 是其边界.P[i] 表示以 i 为中心的最长回文子串的折半长度. 只要 i < mx, 以 i 为中心的回文子串就可以不必从长度1开始找,而从min{P[j], mx - i}开始(其中j为i

[C++]LeetCode: 99 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. 思路:题目要求的s的一个最长回文子串.暴力解决办法就是枚举所有的子串,再对每个子串进行回文判断.进行剪枝,我们考虑可以使用动态规划来避免重复的判

[译]最长回文子串(Longest Palindromic Substring) Part II

[译+改]最长回文子串(Longest Palindromic Substring) Part II 问题:给定字符串S,求S中的最长回文子串. 在上一篇,我们给出了4种算法,其中包括一个O(N2)时间O(1)空间的算法(中心检测法),已经很不错了.本篇将讨论一个O(N)时间O(N)空间的算法,即著名的Manacher算法,并详细说明其时间复杂度为何是O(N). 提示 +BIT祝威+悄悄在此留下版了个权的信息说: 先想想有什么办法能改进中心检测法. 考虑一下最坏的情况.★ 最坏的情况就是各个回文