2021.11.16 P2375 [NOI2014] 动物园(EXKMP+差分)

https://www.luogu.com.cn/problem/P2375

题意:

PS:这道神题的背景让人疑惑,重点是当我飞快磨磨唧唧打出正确自认为正确的代码时,我第三个样例算出了144。讨论区一看,背景有大大的锅,哭了。

有n个字符串,对每个字符串S,设 num[i] 为 \(1 \dots i\) 的不重叠的相同的前缀和后缀的数量

例如: abcababcnum 数组为 \(0,0,0,1,1,1,1,1\) 。

分析:

EXKMP求的是前缀与后缀的最长公共前缀。求出z数组后(我是从0开始求z数组的),对于第 i 位(此时从1开始计算),它所对应的z数组 z[i] 正好是从 i 位(从第0位开始计数的话)开始的后缀与从第0位开始的前缀的最长公共前缀。设 \(x=min(i,z[i])\) , x 表示从第1位开始计数的第 i 位的长度为 i ,和从第0位开始计数的第 i 位的 z[i] 的长度的最小值。如: aaaaa 的z函数为

\[z_0=5,z_1=4,z_2=3,z_3=2,z_4=1
\]

i=1 时,z[1]=4 ,表示后四个a与整个字符串共同前缀最长为4,此时 \(x=min(1,4)=1\) ,表示第 i+x=2 位的 num[2] 增加1。根据题意,前缀与后缀不能重叠,所以最短的才是第 i+x 位的一个不重叠的公共的前缀与后缀的前缀。

当算出来第 i+x 位的 num 增加1时,根据z函数的定义,第 \(i+1 \dots i+x\) 位的 num 都增加了1。

例如: abcdabci=4 时,z[4]=3 , \(x=min(4,3)=3\) ,求出来的是对第 i+x=4+3=7 位的 num 加1,但是同时我们也算出来了对 i+x-1=4+2=6i+1=4+1=5num 加1。

当我开心的写个了for循环搞定这一坨东西后,我发现,我“开心”地TLE了,只有可怜的50分,硬生生写了个kmp也有60分啊……

开始优化:差分是个好东西,把原来最差循环时间复杂度为 \(O(n/2)\) 的立马变为一加一减。

OK,恭喜你,AC这道我第一次见的时候还是紫题的蓝题。

代码如下:

#include<cstdio>
#include<iostream>
#include<algorithm>
#include<cstring>
using namespace std; const int N=1e6+10;
const int mod=1e9+7;
typedef long long ll;
int n,z[N],nexti[N];
char s[N]; inline void getz(char *s){
int len=strlen(s);
z[0]=len;
for(int i=1,l=0,r=0;i<len;i++){
if(i<=r)z[i]=min(z[i-l+1-1],r-i+1);
while(i+z[i]<len&&s[z[i]-1+1]==s[i+z[i]-1+1])++z[i];
if(i+z[i]-1>r)l=i,r=i+z[i]-1;
}
//for(int i=0;i<=len;i++)cout<<z[i]<<" ";cout<<endl;
} int main(){
cin>>n;
while(n--){
memset(z,0,sizeof(z));
memset(nexti,0,sizeof(nexti));
scanf("%s",s);
getz(s);
int len=strlen(s);
for(int i=1;i<=len;i++){
int x=min(z[i],i);
++nexti[i+1];--nexti[i+x+1];
//for(int j=i+x;j>i;j--)++nexti[j];
}
//for(int i=len-1;i>=1;i--)nexti[i]=max(nexti[i+1]-1,nexti[i]);
ll ans=(nexti[1]+nexti[0]+1);
for(int i=2;i<=len;i++)nexti[i]+=nexti[i-1],ans=ans*(nexti[i]+1)%mod;
//for(int i=1;i<=len;i++)cout<<nexti[i]<<" ";cout<<endl;
cout<<ans<<endl;
}
return 0;
}

2021.11.16 P2375 [NOI2014] 动物园(EXKMP+差分)的更多相关文章

  1. 洛谷 P2375 [NOI2014]动物园 解题报告

    P2375 [NOI2014]动物园 题目描述 近日,园长发现动物园中好吃懒做的动物越来越多了.例如企鹅,只会卖萌向游客要吃的.为了整治动物园的不良风气,让动物们凭自己的真才实学向游客要吃的,园长决定 ...

  2. 2021.08.16 P1260 工程规划(差分约束)

    2021.08.16 P1260 工程规划(差分约束) 重点: 1.跑最短路是为了满足更多约束条件. P1260 工程规划 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) 题意: 造 ...

  3. [洛谷P2375] [NOI2014]动物园

    洛谷题目链接:[NOI2014]动物园 题目描述 近日,园长发现动物园中好吃懒做的动物越来越多了.例如企鹅,只会卖萌向游客要吃的.为了整治动物园的不良风气,让动物们凭自己的真才实学向游客要吃的,园长决 ...

  4. 【题解】洛谷P2375 [NOI2014] 动物园(KMP)

    洛谷P2375:https://www.luogu.org/problemnew/show/P2375 思路 这道题可以说是完全刷新了本蒟蒻对KMP的理解 感觉对next数组的理解上升到一个新的高度 ...

  5. 【KMP】洛谷P2375 [NOI2014]动物园 题解

        一开始的方向应该对了,但是没有想到合理的优化还是没写出来…… 题目描述 近日,园长发现动物园中好吃懒做的动物越来越多了.例如企鹅,只会卖萌向游客要吃的.为了整治动物园的不良风气,让动物们凭自己 ...

  6. P2375 [NOI2014]动物园

    考虑kmp. 这个题的主要问题就在于怎样使复杂度是正确的O(n). 可以先预处理一个数组cnt[]表示不考虑不能相交这个限制,有多少个border. 这个东西其实也就是fail树上的深度. 然后考虑怎 ...

  7. P2375 [NOI2014]动物园 KMP

    好,暴力能拿$50pts\space qwq$ 暴力的思路就是一直跳$nxt[j]$,直到它的长度小于串的一半,然后开始计数,当然要接着跳$nxt[j]$ 正解:考虑没有长度要求的(不要求不重合)公共 ...

  8. 洛谷 P2375 [NOI2014]动物园

    题目传送门 解题思路: 其实对于一个sum[i],其值就等于sum[next[i]] + sum[next[next[i]]] + ... + 1,然后我们可以记忆化,然后题目里又有一个限制,就是前后 ...

  9. 日常Java 2021/11/16

    获得applet参数 下面的例子演示了如何使用一个Applet响应来设置文件中指定的参数.该Applet显示了-个黑色棋盘图案和第二种颜色.第二种颜色和每一列的大小通过文档中的Applet的参数指定. ...

随机推荐

  1. IIS将应用程序池配置为在计划时间执行回收 (IIS 7)

    将应用程序池配置为在计划时间执行回收 您可以通过以下方法执行此过程:使用用户界面 (UI).在命令行窗口中运行 Appcmd.exe 命令.直接编辑配置文件或编写 WMI 脚本. 如下只介绍用户界面U ...

  2. loj2341「WC2018」即时战略(随机化,LCT/动态点分治)

    loj2341「WC2018」即时战略(随机化,LCT/动态点分治) loj Luogu 题解时间 对于 $ datatype = 3 $ 的数据,explore操作次数只有 $ n+log n $ ...

  3. 什么是B树(B-树)?

    写在开头:B-树,就是B树.因B树的英文名称为B-tree ,B-树因此而来,有人会误以为B-树是一种树,而B树又是另外一种树.实际上,B-tree就是指的B树. 而且B-树不可以读成B减树... 一 ...

  4. 讲一讲 kafka 的 ack 的三种机制 ?

    request.required.acks 有三个值 0 1 -1(all) 0:生产者不会等待 broker 的 ack,这个延迟最低但是存储的保证最弱当 server 挂 掉的时候就会丢数据. 1 ...

  5. Java 中的 final 关键字有哪些用法?

    修饰类:表示该类不能被继承: 修饰方法:表示方法不能被重写: 修饰变量:表示变量只能一次赋值以后值不能被修改(常量).

  6. 本地连接MySQL云服务器步骤与解决方案

    云服务器:aliyun MySQL 版本:mysql8 第一步首先,检查云服务器的 网络与安全 -> 安全组 是否开放了(MySQL)3306端口 第二步,登陆云服务器上的MySQL,检查需要远 ...

  7. 说出 5 条 IO 的最佳实践?

    IO 对 Java 应用的性能非常重要.理想情况下,你不应该在你应用的关键路径上 避免 IO 操作.下面是一些你应该遵循的 Java IO 最佳实践: a)使用有缓冲区的 IO 类,而不要单独读取字节 ...

  8. git提交错误 git config --global user.email “you@example.com“ git config --global user.name “Your Name

    1 Commit failed - exit code 128 received, with output: '*** Please tell me who you are. 2 3 Run 4 5 ...

  9. 微信小程序要求HTTPS,如何选择SSL证书?

    为了保护小程序应用安全,微信官方的需求文档要求,每个微信小程序必须事先设置一个通讯域名,并通过HTTPS请求进行网络通信,不满足条件的域名和协议无法请求.因此开发者应先准备好配置好HTTPS证书的域名 ...

  10. Javascript--function的name属性

    1.非标准的name属性 function sayHi(){  console.log("Hi");} console.log(sayHi.name);