Pty loves string

建立Border树后,发现可以转化成两个子树中相同点的数量,时间戳转化为连续的区间后相当于有两个数组,每次给两个区间,问区间相同点权的数目。

第一个数组作为区间,第二个数组作为权值。将第一个数组建立主席树,每次插入的是第一个区间位置的权值映射到第二个数组中的权值。然后就是区间查询。

#include<bits/stdc++.h>using namespace std;
const int N=200010;
char s[N];
int n,m;
int ne1[N],ne2[N];
vector<int> e1[N],e2[N];
int dfn1[N],dfn2[N],sz1[N],sz2[N],timestamp;
int id[N];
struct node
{int l,r,v;
}tree[N*40];
int rt[N],cnt;
void insert(int &u,int o,int l,int r,int v)
{tree[u=++cnt]=tree[o];tree[u].v++;if(l==r) return;int mid=l+r>>1;if(v<=mid)insert(tree[u].l,tree[o].l,l,mid,v);elseinsert(tree[u].r,tree[o].r,mid+1,r,v);
}
int query(int u,int o,int l,int r,int L,int R)
{if(L<=l&&r<=R) return tree[u].v-tree[o].v;int v=0;int mid=l+r>>1;if(L<=mid) v+=query(tree[u].l,tree[o].l,l,mid,L,R);if(R> mid) v+=query(tree[u].r,tree[o].r,mid+1,r,L,R);return v;
}
void dfs1(int u)
{sz1[u]=1;dfn1[u]=++timestamp;id[timestamp]=u;for(int v:e1[u]){dfs1(v);sz1[u]+=sz1[v];}
}
void dfs2(int u)
{sz2[u]=1;dfn2[u]=++timestamp;for(int v:e2[u]){dfs2(v);sz2[u]+=sz2[v];}
}
void init()
{for(int i=1;i<=cnt;i++) tree[i]={0,0,0};cnt=0;for(int i=0;i<=n+1;i++) e1[i].clear(),e2[i].clear();ne1[1]=0;for(int i=2,j=0;i<=n;i++){while(j&&s[i]!=s[j+1]) j=ne1[j];if(s[i]==s[j+1]) j++;ne1[i]=j;}ne2[n]=n+1;for(int i=n-1,j=n+1;i;i--){while(j<=n&&s[i]!=s[j-1]) j=ne2[j];if(s[i]==s[j-1]) j--;ne2[i]=j;}
}
void build()
{for(int i=1;i<=n;i++) e1[ne1[i]].push_back(i),e2[ne2[i]].push_back(i);timestamp=0;dfs1(0);timestamp=0;dfs2(n+1);for(int i=1;i<=n+1;i++) insert(rt[i],rt[i-1],1,n+1,dfn2[id[i]+1]);
}
int main()
{int Tc;scanf("%d",&Tc);while(Tc--){scanf("%d%d%s",&n,&m,s+1);init();build();while(m--){int x,y;scanf("%d%d",&x,&y);if(x+y>n) {puts("0");continue;}y=n-y+1;printf("%d\n",query(rt[dfn1[x]+sz1[x]-1],rt[dfn1[x]-1],1,n+1,dfn2[y],dfn2[y]+sz2[y]-1));}}return 0;
}

2021“MINIEYE杯”中国大学生算法设计超级联赛(10)Pty loves string(Border+二维数点)相关推荐

  1. 2021“MINIEYE杯”中国大学生算法设计超级联赛(1)zoto(二维数颜色)

    zoto Code1 树状数组套动态开点权值线段树 效仿HH的项链,维护右端点,询问需要排序 #include<bits/stdc++.h> using namespace std; te ...

  2. 【2021杭电多校赛】2021“MINIEYE杯”中国大学生算法设计超级联赛(3)签到题3题

    2021"MINIEYE杯"中国大学生算法设计超级联赛(3) Start Time : 2021-07-27 12:00:00 End Time : 2021-07-27 17:0 ...

  3. 【2021杭电多校赛】2021“MINIEYE杯”中国大学生算法设计超级联赛(1)签到题15869

    2021"MINIEYE杯"中国大学生算法设计超级联赛(1) Start Time : 2021-07-20 12:10:00 End Time : 2021-07-20 17:1 ...

  4. 2021“MINIEYE杯”中国大学生算法设计超级联赛

    2021"MINIEYE杯"中国大学生算法设计超级联赛 1006 Given a sequence of integers of length n, find the shorte ...

  5. 2021“MINIEYE杯”中国大学生算法设计超级联赛(2)

    2021"MINIEYE杯"中国大学生算法设计超级联赛(2) 1008 I love exam (类背包DP) 1010 I love permutation (数学构造,剩余系) ...

  6. 7068 Dota2 Pro Circuit 杭电多校(2021“MINIEYE杯”中国大学生算法设计超级联赛9) [贪心+双指针]

    题目 Dota2 Pro Circuit *Time Limit: 6000/3000 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Oth ...

  7. 2021“MINIEYE杯”中国大学生算法设计超级联赛(1)个人解题报告

    文章目录 HDU6950 Mod, Or and Everything HDU6954 Minimum spanning tree HDU6958 KD-Graph HDU6957 Maximal s ...

  8. 【2021杭电多校赛】2021“MINIEYE杯”中国大学生算法设计超级联赛(5)签到题4题

    Solved Pro.ID Title Ratio(Accepted / Submitted) 1001 Miserable Faith 33.33%(19/57) 1002 String Mod 2 ...

  9. 【2021杭电多校赛】2021“MINIEYE杯”中国大学生算法设计超级联赛(8)

    1006 GCD Game (博弈论,nim游戏,质因子个数) 题意:有n个数a1,a2....an两个人玩游戏,Alice先动,Bob后动每次可以将一个数变为他的因子,直到不能动就输了. 题解:将问 ...

  10. 2021“MINIEYE杯”中国大学生算法设计超级联赛(8)(1002,1004,1006,1009)

    前言 依旧是白嫖账号,只打了一些题/kk 正题 1002 Buying Snacks 题目大意 nnn个物品,每个可以买一次也可以不买,如果买需要选择1/21/21/2块钱的,然后也可以相邻两个一起买 ...

最新文章

  1. 【总结+计划】2015一月份总结+2015二月份计划——全栈实践
  2. python读取txt文件代码-从文本文件中读取Python代码
  3. Zynq的AMP开发流程说明(基于OCM)
  4. 漫画:什么是MapReduce
  5. 将Matlab程序打包成.exe独立可执行程序
  6. 微博股市直播实时监控提醒
  7. flash游戏开发学习
  8. 华为云服务器最新信息,查询云主机信息
  9. vrchat模型房_vrchat人物模型 1.0 官方版
  10. 解密档案:CTF密码学之RSA攻击算法
  11. 2021智能车小白总结
  12. esp8266保存html文件,八,ESP8266 文件保存数据
  13. FX5U 原点回归指令 DSZR
  14. HTTP响应的内容类型之Content-Type
  15. 先验概率、后验概率、似然概率概念
  16. 【观察】大数据3.0新时代 星环科技的思与行
  17. 介绍部电影“Sicko”,迈克尔摩尔拍摄的抨击美国医疗体制的纪录片
  18. IOS——获取当前运营商(获取漫游接入网络的运营商)
  19. Java源码之从零单排--ArrayList
  20. for_each使用方法详解

热门文章

  1. 在php中使用kind,KindEditor 4.x在PHP中的应用实例!
  2. aspose excel中文文档_除了VBA,还有哪些编程语言可以操作Excel文件?
  3. Maven编译项目时报错:不再支持源选项 5。请使用 6 或更高版本。 不再支持目标选项 1.5。请使用 1.6 或更高版本。
  4. [C++11]独占的智能指针unique_ptr的初始化和使用
  5. [Java基础]IO流概述和分类
  6. [蓝桥杯2017初赛]跳蚱蜢-map标记+bfs+环形数组
  7. 假设一动态集合S用一个长度为m的直接寻址表T来表示。请给出一个查找S中最大元素的过程。(算法导论第十一章11.1-1)
  8. GCD and LCM Aizu - 0005(辗转相除)+GCD LCM Inverse POJ - 2429(java或【Miller Rabin素数測试】+【Pollar Rho整数分解】)
  9. 并查集+基础知识点详解
  10. Leetcode贪心 验证回文字符串