LIGHT OJ 1258 - Making Huge Palindromes 【包含最后一位字符的最长回文串()】

本文介绍了一种通过向字符串右侧添加字符将其转化为最短回文串的方法,并提供了使用Manacher算法实现的具体步骤及示例代码。

1258 - Making Huge Palindromes

Time Limit: 1 second(s)Memory Limit: 32 MB

A string is said to be a palindrome if it remains same when read backwards. So, 'abba', 'madam' both are palindromes, but 'adam' is not.

Now you are given a non-empty string S, containing only lowercase English letters. The given string may or may not be palindrome. Your task is to make it a palindrome. But you are only allowed to add characters at the right side of the string. And of course you can add any character you want, but the resulting string has to be a palindrome, and the length of the palindrome should be as small as possible.

For example, the string is 'bababa'. You can make many palindromes including

bababababab

babababab

bababab

Since we want a palindrome with minimum length, the solution is 'bababab' cause its length is minimum.

Input

Input starts with an integer T (≤ 10), denoting the number of test cases.

Each case starts with a line containing a string S. You can assume that 1 ≤ length(S) ≤ 106.

Output

For each case, print the case number and the length of the shortest palindrome you can make with S.

Sample Input

Output for Sample Input

4

bababababa

pqrs

madamimadam

anncbaaababaaa

Case 1: 11

Case 2: 7

Case 3: 11

Case 4: 19

Note

Dataset is huge, use faster I/O methods.


题意:给定字符串,只能向右边添加任意字符,问使该字符串成为回文串的最小长度是多少;


思路:假设添加过字符后的字符串构成了回文串,那么将串倒置之后的串与原串相同,假设原串长度为len,新串长度为L,也就是说len-1之后的字符都是新添上去的,那么倒置之后的串的0-L-1-(len-1)-1是新添上的,那么中间的部分是原串本来就有的,两串对比=中间的部分回文了,只要找出包含原串最后一位字符的最长回文串的长度,新添字符的长度既可以求出来,再加原串长度即可,求包含最后一个字符的最长回文串的长度操作其实很简单:Manacher从左向右扫描,然后维护mx,我们找到第一个使mx>=新串长度的id返回p[id]-1就是元字符串,注意mx维护的是开区间,即不包括mx这个字符;


失误:想到上述思路之后,我直接用Manacher求最大回文串长度,然后输出(len<<1)减去他,WA了两次才意识到如果最长回文串没有包括最后一个字符的话就错了,因为只能向右边添加字符,如果最长回文串没有包括最后一个字符的话就说明前面没有一个字符和最后有一个字符对称,再添加多少字符也是没用的;


AC代码:

#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;

const int MAXN=3*1e6+66;
char str[MAXN],S[MAXN]; int p[MAXN];

int Manacher(char *S)
{
	int id=0,mx=0,i=0,ans=0;
	int len=strlen(S);
	for(i=1;S[i];++i){
		p[i]=mx>i?min(mx-i,p[(id<<1)-i]):1;
		while(S[i+p[i]]==S[i-p[i]]) ++p[i];
		if(i+p[i]>mx) {
			mx=i+p[i];
			id=i;
		} 
		if(mx>(len-1)) return p[id]-1; 
	}
}
int main()
{
	int T,i,Kase=0;
	scanf("%d",&T);
	while(T--)
	{
	    scanf("%s",str);
		S[0]='$'; S[1]='#';
		for(i=0;str[i];++i)
		{
			S[(i+1)<<1]=str[i];
			S[(i+1)*2+1]='#'; 
		 } 
		 S[(i+1)<<1]='\0';
		 int ans=Manacher(S),len=strlen(str);
		 printf("Case %d: %d\n",++Kase,len-ans+len);
	}
	return 0;
 } 

代码下载地址: https://pan.quark.cn/s/bc087ffa872a "测控电路课后习题详解"文件.pdf是一份极具价值的学术资料,其中系统地阐述了测控电路的基础理论、系统构造、核心特性及其实际应用领域。 以下是对该文献的深入解读和系统梳理:1.1测控电路在测控系统中的核心功能测控电路在测控系统的整体架构中扮演着不可或缺的角色。 它承担着对传感器输出信号进行放大、滤除杂音、提取有效信息等关键任务,并且依据测量与控制的需求,执行必要的计算、处理与变换操作,最终输出能够驱动执行机构运作的指令信号。 测控电路作为测控系统中最具可塑性的部分,具备易于放大信号、转换模式、传输数据以及适应多样化应用场景的优势。 1.2决定测控电路精确度的关键要素影响测控电路精确度的核心要素包括:(1)噪声与干扰的存在;(2)失调现象与漂移效应,尤其是温度引起的漂移;(3)线性表现与保真度水平;(4)输入输出阻抗的特性影响。 在这些要素中,噪声干扰与失调漂移(含温度效应)是最为关键的因素,需要给予高度关注。 1.3测控电路的适应性表现测控电路在测控系统中展现出高度的适应性,具体表现在:* 具备选择特定信号、灵活实施各类转换以及进行信号处理与运算的能力* 实现模数转换与数模转换功能* 在直流与交流、电压与电流信号之间进行灵活转换* 在幅值、相位、频率与脉宽信号等不同参数间进行转换* 实现量程调整功能* 对信号实施多样化的处理与运算,如计算平均值、差值、峰值、绝对值,进行求导数、积分运算等,以及实现非线性环节的线性化处理、逻辑判断等操作1.4测量电路输入信号类型对电路结构设计的影响测量电路的输入信号类型对其电路结构设计产生显著影响。 依据传感器的类型差异,输入信号的形态也呈现多样性。 主要可分为...
(IHAOAVOABPvsAOBPvsAVOABPvsPSOBP)非洲秃鹫融合天鹰优化BP天鹰优化BP非州秃鹫BP粒子群(Matlab代码实现)内容概要:本文档主要围绕多种智能优化算法在不同工程领域的应用展开,重点介绍了非洲秃鹫优化算法(AVOA)、天鹰优化算法(AO)与BP神经网络的融合改进,并与其他经典算法如粒子群优化(PSO)进行对比分析。所有案例均提供Matlab代码实现,涵盖电力系统优化、路径规划、微电网调度、无人机控制、信号处理等多个方向,强调算法的科研复现能力与实际仿真价值。文档还展示了丰富的技术服务体系,涉及机器学习、深度学习、路径规划、通信与电力系统等多个前沿领域。; 适合人群:具备一定Matlab编程基础,从事科研工作或工程仿真的研究生、高校教师及企业研发人员,尤其适用于从事智能优化算法研究与应用的相关技术人员。; 使用场景及目标:①用于学术论文复现,特别是SCI/EI期刊中关于优化算法的实验部分;②为电力系统、无人机、储能调度等领域提供算法仿真技术支持;③帮助研究人员快速掌握多种智能算法的实现方法并进行性能对比。; 阅读建议:建议结合文档提供的网盘资源下载完整代码,按照目录顺序逐步学习,重点关注算法原理与Matlab实现的结合方式,同时可将文中案例作为自身课题的参考模板进行二次开发与创新。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值