2021.11.11 EXKMP

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

下标以1开头:

#include<cstdio>
#include<iostream>
#include<algorithm>
#include<cstring>
using namespace std; const int N=2e7+10;
typedef long long ll;
int lenp,lens,z[N],ext[N];
char t[N],s[N]; inline void getz(char *s){
int n=strlen(s+1);
memset(z,0,sizeof(z));
z[1]=n;
for(int i=2,l=0,r=0;i<=n;i++){
if(i<=r)z[i]=min(z[i-l+1],r-i+1);
while(i+z[i]<=n&&1+z[i]<=n&&s[z[i]+1]==s[(i+z[i]-1)+1])++z[i];
if(i+z[i]-1>r)l=i,r=i+z[i]-1;
}
//z[0]=n;
//cout<<"z "<<endl;//
//for(int i=0;i<=n;i++)cout<<z[i]<<" ";cout<<endl;//
}
inline void exkmp(char *s,char *t){
int n=strlen(s+1),m=strlen(t+1);
getz(t);
ll ans=0;
for(int i=1;i<=m;i++)ans^=1ll*(i)*(z[i]+1);
cout<<ans<<endl;
memset(ext,0,sizeof(ext));
for(int i=1,l=0,r=0;i<=n;i++){
if(i<=r)ext[i]=min(z[i-l+1],r-i+1);
while(i+ext[i]<=n&&1+ext[i]<=m&&t[ext[i]+1]==s[(i+ext[i]-1)+1])++ext[i];
if(r<i+ext[i]-1)l=i,r=i+ext[i]-1;
}
ans=0;
for(int i=1;i<=n;i++)ans^=1ll*(i)*(ext[i]+1);
cout<<ans;
//cout<<"ext"<<endl;//
//for(int i=0;i<=n;i++)cout<<ext[i]<<" ";cout<<endl;//
} int main(){
scanf("%s",s+1);scanf("%s",t+1);
exkmp(s,t);
return 0;
}

下标以0开始:

#include<cstdio>
#include<iostream>
#include<algorithm>
#include<cstring>
using namespace std; const int N=2e7+10;
typedef long long ll;
int lenp,lens,z[N],ext[N];
char t[N],s[N]; inline void getz(char *s){
int len=strlen(s);
memset(z,0,sizeof(z));
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]]==s[(i+z[i]-1)+1])++z[i];
if(i+z[i]-1>r)l=i,r=i+z[i]-1;
}
ll ans=0;
for(int i=0;i<len;i++)ans^=1ll*(i+1)*(z[i]+1);
cout<<ans<<endl;
}
inline void exkmp(char *s,char *t){
getz(t);
int lens=strlen(s),lent=strlen(t);
for(int i=0,l=-1,r=-1;i<lens;i++){
if(i<=r)ext[i]=min(z[(i-l+1)-1],r-i+1);
while(i+ext[i]<lens&&ext[i]<lent&&t[ext[i]]==s[(i+ext[i]-1)+1])++ext[i];
if(i+ext[i]-1>r)l=i,r=i+ext[i]-1;
}
ll ans=0;
for(int i=0;i<lens;i++)ans^=1ll*(i+1)*(ext[i]+1);
cout<<ans<<endl;
} int main(){
scanf("%s",s);scanf("%s",t);
exkmp(s,t);
return 0;
}

练习题

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

论树状数组的好用 ~

#include<cstdio>
#include<iostream>
#include<algorithm>
#include<cstring>
using namespace std; const int N=1e5+10;
int z[N],ext[N],t[N],top;
char s[N*2];
struct node{
int len,tot;
bool operator <(const node &b)const{
return len<b.len;
}
}ans[N]; inline void getz(char *s){
int n=strlen(s+1);
z[1]=n;
for(int i=2,l=0,r=0;i<=n;i++){
if(i<=r)z[i]=min(z[i-l+1],r-i+1);
while(i+z[i]<=n&&s[z[i]+1]==s[(i+z[i]-1)+1])++z[i];
if(i+z[i]-1>r)l=i,r=i+z[i]-1;
}
}
inline void exkmp(char *s,char *t){
int lens=strlen(s+1),lent=strlen(t+1);
getz(t);
for(int i=1,l=-1,r=-1;i<=lens;i++){
if(i<=r)ext[i]=min(z[i-l+1],r-i+1);
while(i+ext[i]<=lens&&1+ext[i]<=lent&&t[ext[i]+1]==s[(i+ext[i]-1)+1])++ext[i];
if(i+ext[i]-1>r)l=i,r=i+ext[i]-1;
}
}
inline int lowbit(int x){
return x&-x;
}
inline void add(int x,int k,int len){
for(int i=x;i<=len;i+=lowbit(i))t[i]+=k;
}
inline int query(int x){
int fin=0;
for(int i=x;i>0;i-=lowbit(i))fin+=t[i];
return fin;
} int main(){
scanf("%s",s+1);
int len=strlen(s+1);
//cout<<len<<endl;
s[len+1]='|';
for(int i=1;i<=len;i++)s[i+len+1]=s[i];
//for(int i=1;i<=len*2+2;i++)printf("%c",s[i]);cout<<endl;
int leni=strlen(s+1);
//cout<<leni<<endl;
getz(s);
//for(int i=1;i<=leni;i++)cout<<z[i]<<" ";cout<<endl;
for(int i=len+2;i<=leni;i++)if(z[i])add(z[i],1,len);
for(int i=len+2;i<=leni;i++)if(i+z[i]-1==leni){
++top;
ans[top].len=z[i];ans[top].tot=query(len)-query(z[i]-1);
}
sort(ans+1,ans+top+1);
cout<<top<<endl;
for(int i=1;i<=top;i++)cout<<ans[i].len<<" "<<ans[i].tot<<endl;
return 0;
}

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

https://www.luogu.com.cn/blog/nitubenben/solution-p7114

PS:树状数组是EXKMP的好帮手~

#include<cstdio>
#include<iostream>
#include<algorithm>
#include<cstring>
using namespace std; const int N=(1<<20)+10;
typedef long long ll;
int t,z[N],before[N],after[N],tree[N];
char s[N]; inline void getz(char *s){
int n=strlen(s);
z[0]=n;
for(int i=1,l=0,r=0;i<n;i++){
if(i<=r)z[i]=min(z[(i-l+1)-1],r-i+1);
while(i+z[i]<n&&s[z[i]]==s[(i+z[i]-1)+1])++z[i];
if(i+z[i]-1>r)l=i,r=i+z[i]-1;
}
}
inline int lowbit(int x){
return x&-x;
}
inline void add(int x,int k,int n){
for(int i=x;i<=n;i+=lowbit(i))tree[i]+=k;
}
inline int query(int x){
int fin=0;
for(int i=x;i>0;i-=lowbit(i))fin+=tree[i];
return fin;
} int main(){
cin>>t;
while(t--){
memset(z,0,sizeof(z));
memset(after,0,sizeof(after));
memset(before,0,sizeof(before));
memset(tree,0,sizeof(tree));
scanf("%s",s);
getz(s);
int n=strlen(s);
for(int i=0;i<n;i++)if((i+z[i]-1)+1==n)--z[i];
for(int i=0;i<n;i++)++after[s[i]-'a'];
int all=0,pre=0,suf=0;
ll ans=0;
for(int i=0;i<26;i++)if(after[i]&1)++all;
suf=all;
for(int i=0;i<n;i++){
int x=s[i]-'a';
if(after[x]&1)--suf;
else ++suf;
--after[x];
if(before[x]&1)--pre;
else ++pre;
++before[x];
if(i&&i!=n-1){
int num=z[i+1]/(i+1)+1;
ans+=1ll*(num/2)*query(all+1)+1ll*(num-num/2)*query(suf+1);
}
add(pre+1,1,n);
}
cout<<ans<<endl;
}
return 0;
}

2021.11.11 EXKMP的更多相关文章

  1. 2021.11.11 P4052 [JSOI2007]文本生成器(AC自动机+DP)

    2021.11.11 P4052 [JSOI2007]文本生成器(AC自动机+DP) https://www.luogu.com.cn/problem/P4052 题意: JSOI 交给队员 ZYX ...

  2. NOIp 11.11/12

    最后一场比较正式的NOIp模拟赛,写一发小总结.题目没什么好说的,大部分很简单,先贴一下代码. 1111 T1 //string //by Cydiater //2016.11.11 #include ...

  3. 11.11光棍节工作心得——github/MVP

    11.11光棍节工作心得 1.根据scrum meeting thirdday中前辈的指导进行学习 我在博客中贴了链接,竟然TrackBack引来了原博主,

  4. 下面程序的输出结果是____ A:11,10 B:11,11 C:10,10 D:10,11 int x=10; int y=x++; printf("%d,%d",(x++,y),y++);

    下面程序的输出结果是____ A:11,10 B:11,11 C:10,10 D:10,11 int x=10; int y=x++; printf("%d,%d",(x++,y) ...

  5. Hadoop格式化 From hu-hadoop1/192.168.11.11 to hu-hadoop2:8485 failed on connection exception: java.net.

    192.168.11.12:8485: Call From hu-hadoop1/192.168.11.11 to hu-hadoop2:8485 failed on connection excep ...

  6. 〖Linux〗iptables端口转发(11.11.136.80:5552 <==> 10.10.136.1:8055/11.11.136.1:8055)

    环境: pc1: 10.10.72.1 (network: 10.10.72.0/22) pc2: 地址1: 10.10.136.1 (nework: 10.10.136.0/22) 地址2: 11. ...

  7. 2017.11.11 B201 练习题思路及解题方法

    2017.11.11 B201 练习题思路及解题方法 题目类型及涵盖知识点 本次总共有6道题目,都属于MISC分类的题目,涵盖的知识点有 信息隐藏 暴力破解 音轨,摩斯电码 gif修改,base64原 ...

  8. Notes of Daily Scrum Meeting(11.11)

    Notes of Daily Scrum Meeting(11.11) 今天是11月11号光棍节,不知道大家的购物热情被点燃没有,有没有买到自己心仪的东西.额,今天我们的团队任务进度和昨天差不多, 每 ...

  9. TeamWork#3,Week5,Scrum Meeting 11.6, 11.7, 11.11, 11.12

    11.6:到目前为止基本已完成相关知识的学习,各方面工作都开始进行,一开始进行比较慢. 11.7:项目遇到困难,需要补充相关知识,进度慢了下来. 11.11:各方面工作进展比较顺利,没有什么大问题. ...

随机推荐

  1. sql中数据统计

    今天来说一下使用sql统计数据. 用的H2数据库,用的是DBeaver连接工具.有三表,打印表PRINT_JOB,复印表COPY_JOB和扫描表SCANNER_JOB (这段可以忽略)任务是要统计相同 ...

  2. 论文解读(SUGRL)《Simple Unsupervised Graph Representation Learning》

    Paper Information Title:Simple Unsupervised Graph Representation LearningAuthors: Yujie Mo.Liang Pen ...

  3. mock axios vue的数据传递关系

    最近有一个项目要快速出一个前端demo,选择了vue-element框架(虽然其实很想用react,但是为了求快) 本人的基础只有初级的html/css/js知识,和python后端的一些简单工作,和 ...

  4. 浅析MySQL恶意服务器读取文件原理

    前言 注:本文不涉及对MySQL协议报文研究,仅讲解原理,并且做部分演示. 搭建MySQL恶意服务器读取文件这件事,虽然直接利用门槛较高,但是由于在网上看到了一种比较新颖的利用方式(利用社会工程学引诱 ...

  5. 百度Paddle速查_CPU和GPU的mnist预测训练_模型导出_模型导入再预测_导出onnx并预测

    需要做点什么 方便广大烟酒生研究生.人工智障炼丹师算法工程师快速使用百度PaddelPaddle,所以特写此文章,默认使用者已有基本的深度学习概念.数据集概念. 系统环境 python 3.7.4 p ...

  6. Java 框架、库和软件的精选列表(awesome java)

    原创翻译,原始链接 本文为awesome系列中的awesome java Awesome Java Java 框架.库和软件的精选列表 项目 Bean映射 简化 bean 映射的框架 dOOv - 为 ...

  7. 使用Web Deploy自动打包发布

    在内部测试阶段,经常改一点小东西需要更新给测试继续测试.然后就需要频繁的找到对应更改的视图/JS文件,或者是编译的dll文件,再打开测试服务器找到对应站点替换进去,整套流程下来就非常的繁琐费时. 使用 ...

  8. Makefile学习(一)

       objects = main.o kbd.o command.o display.o \              insert.o search.o files.o utils.o       ...

  9. 实验:zk master宕机后,临时节点在新的master上是否存在,结果出人意料

    一.实验 实验说明:3台zk集群,主要验证:master上的客户端,在master上建立临时节点,当master宕机时,其他follower选为主后,临时节点是否存在. 主要是通过此来验证,基于zk的 ...

  10. 使用IDEA开发SpringBoot不加载application.yml配置文件的解决方案

    1.如果启动项目不加载application.yml配置文件,那么请确认下是否应用了Resources为项目资源文件夹 2.如果项目起初是可以正常使用的,突然不知道改了什么,然后进行启动项目的时候不加 ...