BZOJ.1535.[POI2005]SZA-Template(KMP DP)
\(Description\)
给定一个字符串\(s\),求一个最短的字符串\(t\)满足,将\(t\)拼接多次后,可以得到\(s\)。拼接是指,可以将\(t\)放在当前串的任意位置,但要保证对应位置相同。(不太会说,看样例吧...)
\(|s|\leq5\times10^5\)。
\(Solution\)
首先\(t\)既是\(s\)的前缀也是\(s\)的后缀,即\(s\)的\(border\)、\(border\)的\(border\)...
考虑\(KMP\)建出\(fail\)树,那么\(t\)是\(n\)到根节点路径上的某个节点。考虑路径上怎样的节点是合法的。
\(s\)中能够放\(t\)的位置\(i\)满足,\(t\)是\(s[1...i]\)的\(border\)或者\(border\)的\(border\)...即在\(fail\)树中\(i\)在\(t\)的子树内。对于所有\(i\),要满足相邻的\(i\)之间的最大间距不超过\(|t|\),这样\(t\)就是合法的。
注意到从根节点到\(n\)的路径中,要维护的这个最大间距是递减的(每次删掉若干棵子树中的\(i\))。那么删除一个位置时,用链表维护下相邻位置的最大间距就可以了。
还有一个更简单的DP方法,看洛谷题解吧,我还不是很理解就不写了。
//20760kb	320ms
#include <cstdio>
#include <cctype>
#include <cstring>
#include <algorithm>
#define gc() getchar()
typedef long long LL;
const int N=5e5+5;
int fail[N],H[N],nxt[N],way[N],L[N],R[N],Max;
char s[N];
inline void AE(int u,int v)
{
	nxt[v]=H[u], H[u]=v;
}
void Delete(int x)
{
	L[R[x]]=L[x], R[L[x]]=R[x], Max=std::max(Max,R[x]-L[x]);
	for(int v=H[x]; v; v=nxt[v]) if(v!=way[x]) Delete(v);
}
int main()
{
	scanf("%s",s+1); int n=strlen(s+1);
	for(int i=2,j=0; i<=n; ++i)
	{
		while(j&&s[i]!=s[j+1]) j=fail[j];
		fail[i]=s[i]==s[j+1]?++j:0;
	}
	for(int i=1; i<=n; ++i) L[i]=i-1, R[i]=i+1, AE(fail[i],i);
	for(int x=n; x; x=fail[x]) way[fail[x]]=x;
	int x=0;
	for(Max=1; Max>x; x=way[x]) Delete(x);
	printf("%d\n",x);
	return 0;
}
												
											BZOJ.1535.[POI2005]SZA-Template(KMP DP)的更多相关文章
- [BZOJ 1535] [Luogu 3426]SZA-Template (KMP+fail树+双向链表)
		
[BZOJ 1535] [Luogu 3426]SZA-Template (KMP+fail树+双向链表) 题面 Byteasar 想在墙上涂一段很长的字符,他为了做这件事从字符的前面一段中截取了一段 ...
 - 2021.11.09 P3426 [POI2005]SZA-Template(KMP+DP)
		
2021.11.09 P3426 [POI2005]SZA-Template(KMP+DP) https://www.luogu.com.cn/problem/P3426 题意: 你打算在纸上印一串字 ...
 - BZOJ.1009.[HNOI2008]GT考试(KMP DP 矩阵快速幂)
		
题目链接 设f[i][j]为当前是第i位考号.现在匹配到第j位(已有j-1位和A[]匹配)的方案数 因为假如当前匹配j位,如果选择的下一位与A[j+1]不同,那么新的匹配位数是fail[j]而不是0, ...
 - bzoj 1537 [POI2005]Aut- The Bus(DP+BIT)
		
[题意] 顺序经过k个点,求获得的最大权值和. [思路] 设f[i]表示到第i个点,则有转移式: f[i]=min{ f[j]+w[i] } x[j]<=x[i],y[j]<=y[i] 满 ...
 - bzoj 1537: [POI2005]Aut- The Bus 线段树
		
bzoj 1537: [POI2005]Aut- The Bus 先把坐标离散化 设f[i][j]表示从(1,1)走到(i,j)的最优解 这样直接dp::: f[i][j] = max{f[i-1][ ...
 - [HDOJ5763]Another Meaning(KMP, DP)
		
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5763 题意:给定两个字符串a和b,其中a中的字符串如果含有子串b,那么那部分可以被替换成*.问有多少种 ...
 - POJ 3336 Count the string (KMP+DP,好题)
		
参考连接: KMP+DP: http://www.cnblogs.com/yuelingzhi/archive/2011/08/03/2126346.html 另外给出一个没用dp做的:http:// ...
 - [BZOJ 4033] [HAOI2015] T1 【树形DP】
		
题目链接:BZOJ - 4033 题目分析 使用树形DP,用 f[i][j] 表示在以 i 为根的子树,有 j 个黑点的最大权值. 这个权值指的是,这个子树内部的点对间距离的贡献,以及 i 和 Fat ...
 - 【KMP+DP】Count the string
		
KMP算法的综合练习 DP很久没写搞了半天才明白.本题结合Next[]的意义以及动态规划考察对KMP算法的掌握. Problem Description It is well known that A ...
 
随机推荐
- C# Parallel并发执行相关问题
			
1.Parallel并发执行 using System;using System.Collections.Generic;using System.Linq;using System.Text;usi ...
 - JAVA代码中可使用中文类名,变量名,对象名,方法名.
			
java程序 兔子 public class 兔子{ //构造方法 public 兔子(){} public void 吃草(){ System.out.println("兔子在吃草&quo ...
 - 51 nod 1212 无向图最小生成树(Kruckal算法/Prime算法图解)
			
1212 无向图最小生成树 N个点M条边的无向连通图,每条边有一个权值,求该图的最小生成树. 收起 输入 第1行:2个数N,M中间用空格分隔,N为点的数量,M为边的数量.(2 <= N < ...
 - 【专栏学习】APM——异步编程模型(.NET不推荐)
			
(1)learning hard C#学习笔记 异步1:<learning hard C#学习笔记>读书笔记(20)异步编程 (2)<C# 4.0 图解教程> 22.4 异步编 ...
 - Redis cluster集群模式的原理
			
redis cluster redis cluster是Redis的分布式解决方案,在3.0版本推出后有效地解决了redis分布式方面的需求 自动将数据进行分片,每个master上放一部分数据 提供内 ...
 - C#学习-方法
			
方法是由方法签名和一系列语句的代码块组成. 其中方法签名包括方法的访问级别(比如public或private).可修饰符(例如abstract关键字).方法名称和参数. C#也支持方法重载.方法重载指 ...
 - Spring MVC基础知识整理➣拦截器和自定义注解
			
概述 Spring MVC中通过注解来对方法或者类进行动态的说明或者标注,类似于配置标识文件的属性信息.当标注的类或者方式被使用时候,通过提取注解信息来达到对类的动态处理.在 MVC中,我们常用的注解 ...
 - 【译】学习JavaScript中提升、作用域、闭包的终极指南
			
这似乎令人惊讶,但在我看来,理解JavaScript语言最重要和最基本的概念是理解执行上下文.通过正确学习它,你将很好地学习更多高级主题,如提升,作用域链和闭包.考虑到这一点,究竟什么是"执 ...
 - Apache Tomcat RCE(CVE-2017-12615 )漏洞案例分析
			
首先搭建tomcat环境: 下载当前项目的版本的tomcat
 - Python学习(三) —— 基本数据类型
			
基本数据类型 一.整数类型(int) 32位机器,整数的位数为32位,取值范围为-2**31~2**31-1,即-2147483648~2147483647 64位机器,整数的位数是64位,取值范围位 ...