由于春希对于第二世代操作的不熟练,所以刚使用完\(invasion process\)便掉落到了世界线之外,错综复杂的平行世界信息涌入到春希的意识中。春希明白了事件的真相。

在一个冬马与雪菜同时存在的世界里,傲娇的冬马最终还是博得了春希的内心。然而看着好友雪菜的消瘦,内心愧疚的冬马启动了第二世代操作,想找到一个雪菜最终成功的世界,却发现哪里都没有。绝望的冬马决定耗尽自己全部的第二世代操作点数,自创一个没有自己只有雪菜与春希的世界。

虽然这个世界一开始效果很好,春希与雪菜很快的被命运撮合在了一起,然而没有了冬马的雪菜,如没有了大海的沙滩,失去了傍依。

虽然世界里没有冬马的存在,但是由于冬马创造时的疏忽,这个世界里的雪菜依然存在着因独占春希而产生的对冬马的愧疚感,这种愧疚感折磨着雪菜,最终雪菜选择了自毁忘记春希。

看着这一切的春希深知不管是三个人一起的快乐,还是两个人独处的甜蜜,都无法消除冬马与雪菜内心的自责,无论如何修改世界,三人都只会更加痛苦,于是春希使用了自己剩余的全部操作点数,念出了\(key world:WhiteAlbum2\),开始了\(initialization process\).

在\(initialization process\)中,春希需要整理世界线,才能回归原本的世界。

世界线是一棵根节点为1的树,每个节点为1个字符。规定树上的子串为从某个节点(不一定是1号节点)出发往其子节点走所形成的字符串。每一个子串相当于一个平行世界,要想重构世界,就需要知道两个信息:

  1. 不同子串的个数
  2. 将不同的子串排序后,字典序第\(k-1\)小的子串。

    如图所示为一个世界线的样例,从\(4->5\)的子串为\(bb\),\(1->5\)的为\(abb\)

Input

第一行两个整数\(n\),\(q\)表示节点个数以及询问个数

第二行\(n\)个字符,表示编号为\(i\)的字符是什么。

接下来\(n-1\)行表示一棵树。

接下来\(q\)行,每行一个整数\(k\)

Output

第一行为不同支付串个数。

接下来q行为q个询问的答案(注意输出的是第\(k-1\)小的子串,如果\(k=1\)请直接换行),如果不存在(不包括\(k=1\))输出\(-1\).

Sample Input

  1. 8 1
  2. abcbbaca
  3. 1 2
  4. 2 3
  5. 1 4
  6. 4 5
  7. 4 6
  8. 4 7
  9. 1 8
  10. 5

Sample Output

  1. 12
  2. aba

Hint

12%:\(n<=10\)

另有48%为一条链;

100%: \(n<=250000\),\(q<=50000\).

题意:

给出一棵\(trie\)树,求出上面所有字符串的本质不同的子串的总数(算上空串),并求出其中的第\(k\)大子串。

题解:

给每个节点记录一个\(last\),每次加入字符的时候把\(last\)设为其父节点记录的\(last\),然后就可以像普通的后缀自动机一样建了。最后找第\(k\)小的子串如这个就行了

  1. #include<bits/stdc++.h>
  2. using namespace std;
  3. const int N=600010;
  4. int n,q;
  5. int tot,bian[N<<1],nxt[N<<1],head[N];
  6. inline void add(int x,int y){
  7. tot++,bian[tot]=y,nxt[tot]=head[x],head[x]=tot;
  8. }
  9. char s[N];
  10. int a[N],c[N];
  11. struct SAM{
  12. int lst[N],last,cnt,now;
  13. long long size[N];
  14. int ch[N][26],fa[N<<1],l[N<<1];
  15. void ins(int c){
  16. if(ch[last][c]&&l[ch[last][c]]==l[last]+1){
  17. last=ch[last][c];
  18. return;
  19. }
  20. int p=last,np=++cnt;last=np;l[np]=l[p]+1;
  21. for(;p&&!ch[p][c];p=fa[p])ch[p][c]=np;
  22. if(!p)fa[np]=1;
  23. else{
  24. int q=ch[p][c];
  25. if(l[p]+1==l[q])fa[np]=q;
  26. else{
  27. int nq=++cnt;l[nq]=l[p]+1;
  28. memcpy(ch[nq],ch[q],sizeof ch[q]);
  29. fa[nq]=fa[q];fa[q]=fa[np]=nq;
  30. for(;p&&ch[p][c]==q;p=fa[p])ch[p][c]=nq;
  31. size[nq]=1;
  32. }
  33. }
  34. size[np]=1;
  35. }
  36. void dfs(int x,int f){
  37. last=lst[f];
  38. now=x;
  39. ins(s[x]-'a');
  40. lst[x]=last;
  41. for(int i=head[x];i;i=nxt[i]){
  42. int y=bian[i];
  43. if(f==bian[i])continue;
  44. dfs(y,x);
  45. last=lst[x];
  46. }
  47. }
  48. void build(){
  49. lst[0]=1;cnt=1;
  50. dfs(1,0);
  51. }
  52. void calc(){
  53. int ans=0;
  54. for(int i=1;i<=cnt;++i)c[l[i]]++;
  55. for(int i=1;i<=cnt;++i)c[i]+=c[i-1];
  56. for(int i=1;i<=cnt;++i)a[c[l[i]]--]=i;
  57. for(int i=cnt;i;--i){
  58. int p=a[i];
  59. for(int j=0;j<26;++j){
  60. if(ch[p][j])size[p]+=size[ch[p][j]];
  61. }
  62. }
  63. }
  64. void find(int k){
  65. int p=1;
  66. while(k){
  67. int a=0;
  68. while(k>size[ch[p][a]]&&a<26){
  69. if (ch[p][a]) k-=size[ch[p][a]];
  70. a++;
  71. }
  72. putchar('a'+a);k--;
  73. p=ch[p][a];
  74. }
  75. }
  76. }sam;
  77. int main(){
  78. cin>>n>>q;
  79. cin>>s+1;
  80. for(int i=1;i<n;++i){
  81. int x,y;
  82. scanf("%d%d",&x,&y);
  83. add(x,y);
  84. add(y,x);
  85. }
  86. sam.build();
  87. sam.calc();
  88. long long sm;
  89. cout<<(sm=sam.size[1]+1)<<endl;
  90. while(q--){
  91. long long k;
  92. scanf("%lld",&k);
  93. if(k==1){
  94. puts("");
  95. }else{
  96. if(k>sm)puts("-1");
  97. else sam.find(k-1),putchar('\n');
  98. }
  99. }
  100. }

世界线(bzoj2894)(广义后缀自动机)的更多相关文章

  1. BZOJ 2894: 世界线 广义后缀自动机

    Code: #include<bits/stdc++.h> #define maxn 300000 #define ll long long using namespace std; ve ...

  2. bzoj3926: [Zjoi2015]诸神眷顾的幻想乡 对[广义后缀自动机]的一些理解

    先说一下对后缀自动机的理解,主要是对构造过程的理解. 构造中,我们已经得到了前L个字符的后缀自动机,现在我们要得到L+1个字符的后缀自动机,什么需要改变呢? 首先,子串$[0,L+1)$对应的状态不存 ...

  3. BZOJ 3926 && ZJOI 2015 诸神眷顾的幻想乡 (广义后缀自动机)

    3926: [Zjoi2015]诸神眷顾的幻想乡 Time Limit: 10 Sec Memory Limit: 512 MB Description 幽香是全幻想乡里最受人欢迎的萌妹子,这天,是幽 ...

  4. BZOJ 3277 串 (广义后缀自动机)

    3277: 串 Time Limit: 10 Sec Memory Limit: 128 MB Submit: 309 Solved: 118 [Submit][Status][Discuss] De ...

  5. BZOJ 3473: 字符串 [广义后缀自动机]

    3473: 字符串 Time Limit: 20 Sec  Memory Limit: 256 MBSubmit: 354  Solved: 160[Submit][Status][Discuss] ...

  6. BZOJ.2780.[SPOJ8093]Sevenk Love Oimaster(广义后缀自动机)

    题目链接 \(Description\) 给定n个模式串,多次询问一个串在多少个模式串中出现过.(字符集为26个小写字母) \(Solution\) 对每个询问串进行匹配最终会达到一个节点,我们需要得 ...

  7. BZOJ.3926.[ZJOI2015]诸神眷顾的幻想乡(广义后缀自动机)

    题目链接 要对多个串同时建立SAM,有两种方法: 1.将所有串拼起来,中间用分隔符隔开,插入字符正常插入即可. 2.在这些串的Trie上建SAM.实际上并不需要建Trie,还是只需要正常插入(因为本来 ...

  8. 【CF666E】Forensic Examination 广义后缀自动机+倍增+线段树合并

    [CF666E]Forensic Examination 题意:给你一个字符串s和一个字符串集合$\{t_i\}$.有q个询问,每次给出$l,r,p_l,p_r$,问$s[p_l,p_r]$在$t_l ...

  9. cf666E. Forensic Examination(广义后缀自动机 线段树合并)

    题意 题目链接 Sol 神仙题Orz 后缀自动机 + 线段树合并 首先对所有的\(t_i\)建个广义后缀自动机,这样可以得到所有子串信息. 考虑把询问离线,然后把\(S\)拿到自动机上跑,同时维护一下 ...

随机推荐

  1. RPM包制作方法

    一.RPM介绍 RPM 前是Red Hat Package Manager 的缩写,本意是Red Hat 软件包管理,顾名思义是Red Hat 贡献出来的软件包管理:现在应为RPM Package M ...

  2. abort: no username supplied (see "hg help config")

    abort: no username supplied (see "hg help config") 在hg中输入commit 指令时,如果出现下述结果: $ hg commit ...

  3. Laravel5.5 使用队列 Queue

    使用队列# 上一章节中我们开发了自动生成 Slug 功能,但是因为我们的需要实时请求百度翻译接口,这将会是一个系统性能隐患. 一般情况下,网络请求会存在各种不确定性,如果请求 API 出现超时情况,或 ...

  4. [SoapUI] How to create a random UUID in each Request's Headers

    ${=java.util.UUID.randomUUID()}  is OK

  5. WCF TOOL CODE

    .HTML <%@ Page Language="C#" AutoEventWireup="true" CodeBehind="WCFTool. ...

  6. $.fn.extend 和$.extend函数

    区别和详解:jQuery extend()和jQuery.fn.extend()     首先是简单的概述区别:$.extend()是类方法   $.fn.extend()是原型方法   对象方法和原 ...

  7. 44 The shopping psychology 购物心理

    The shopping psychology 购物心理 ①People can be addicted to different things ---e. g.,alcohol, drugs, ce ...

  8. SpringMVC上传图片总结(2)--- 使用百度webuploader上传组件进行上传图片

    SpringMVC上传图片总结(2)--- 使用百度webuploader上传组件进行上传图片   在上一篇文章中,我们介绍了< SpringMVC上传图片的常规上传方法 >.本文接着第一 ...

  9. 201709015工作日记--上下文的理解,ASM

    1.Android上下文理解 Android上下文对象,在Context中封装一个所谓的“语境”,Activity.Service.Application都继承自Context,所以在这三者创建时都会 ...

  10. (并查集)Is It A Tree? --POJ--1308

    链接: http://poj.org/problem?id=1308 http://acm.hust.edu.cn/vjudge/contest/view.action?cid=82830#probl ...