字符串好难啊不会啊

  1. #include <iostream>
  2. #include <cstdio>
  3. using namespace std;
  4. int n, m, rnk[100005], cnt[100005], tmp[100005], p, mx=128, saa[100005], tot, a, b;
  5. int height[100005], gg[19][100005], mlg[100005], rot[100005], c, d;
  6. char ss[100005];
  7. struct Node{
  8. int l, r, sum;
  9. }nd[2000005];
  10. void sasort(){
  11. for(int i=0; i<mx; i++) cnt[i] = 0;
  12. for(int i=0; i<n; i++) cnt[rnk[i]]++;
  13. for(int i=1; i<mx; i++) cnt[i] += cnt[i-1];
  14. for(int i=n-1; i>=0; i--) saa[--cnt[rnk[tmp[i]]]] = tmp[i];
  15. }
  16. void getSa(){
  17. for(int i=0; i<n; i++){
  18. rnk[i] = ss[i];
  19. tmp[i] = i;
  20. }
  21. sasort();
  22. for(int j=1; p<n; j<<=1){
  23. p = 0;
  24. for(int i=n-j; i<n; i++) tmp[p++] = i;
  25. for(int i=0; i<n; i++)
  26. if(saa[i]>=j)
  27. tmp[p++] = saa[i] - j;
  28. sasort();
  29. swap(rnk, tmp);
  30. p = 1;
  31. rnk[saa[0]] = 0;
  32. for(int i=1; i<n; i++)
  33. if(tmp[saa[i-1]]==tmp[saa[i]] && tmp[saa[i-1]+j]==tmp[saa[i]+j])
  34. rnk[saa[i]] = p - 1;
  35. else
  36. rnk[saa[i]] = p++;
  37. mx = p;
  38. }
  39. }
  40. void getHeight(){
  41. int h=0;
  42. for(int i=0; i<n; i++){
  43. if(h) h--;
  44. int j=saa[rnk[i]-1];
  45. while(ss[i+h]==ss[j+h]) h++;
  46. height[rnk[i]] = h;
  47. }
  48. }
  49. void getRmq(){
  50. for(int i=1; i<=n; i++) gg[0][i] = height[i];
  51. for(int j=1; j<=17; j++)
  52. for(int i=1; i<=n; i++){
  53. if(i+(1<<(j-1))>n) break;
  54. gg[j][i] = min(gg[j-1][i], gg[j-1][i+(1<<(j-1))]);
  55. }
  56. }
  57. int update(int pre, int l, int r, int x){
  58. int re=++tot;
  59. nd[re] = nd[pre];
  60. nd[re].sum++;
  61. if(l==r) ;
  62. else{
  63. int mid=(l+r)>>1;
  64. if(x<=mid) nd[re].l = update(nd[pre].l, l, mid, x);
  65. else nd[re].r = update(nd[pre].r, mid+1, r, x);
  66. }
  67. return re;
  68. }
  69. bool query(int pre, int now, int l, int r, int x, int y){
  70. if(l>=x && r<=y) return nd[now].sum-nd[pre].sum>0;
  71. else{
  72. int mid=(l+r)>>1;
  73. bool re=false;
  74. if(x<=mid) re |= query(nd[pre].l, nd[now].l, l, mid, x, y);
  75. if(mid<y) re |= query(nd[pre].r, nd[now].r, mid+1, r, x, y);
  76. return re;
  77. }
  78. }
  79. int main(){
  80. cin>>n>>m;
  81. scanf("%s", ss);
  82. ss[n++] = 0;
  83. getSa();
  84. n--;
  85. getHeight();
  86. getRmq();
  87. for(int i=1; i<=n; i++)
  88. rot[i] = update(rot[i-1], 1, n, rnk[i-1]);
  89. while(m--){
  90. scanf("%d %d %d %d", &a, &b, &c, &d);
  91. int l=1, r=min(b-a+1, d-c+1), mid, re=0;
  92. while(l<=r){
  93. mid = (l + r) >> 1;
  94. int zuo=rnk[c-1], you=rnk[c-1];
  95. for(int i=17; i>=0; i--)
  96. if(zuo>=(1<<i) && gg[i][zuo-(1<<i)+1]>=mid)
  97. zuo -= 1<<i;
  98. for(int i=17; i>=0; i--)
  99. if(you+(1<<i)<=n && gg[i][you+1]>=mid)
  100. you += 1<<i;
  101. if(query(rot[a-1], rot[b-mid+1], 1, n, zuo, you))
  102. re = mid, l = mid + 1;
  103. else
  104. r = mid - 1;
  105. }
  106. printf("%d\n", re);
  107. }
  108. return 0;
  109. }

loj2059 「TJOI / HEOI2016」字符串的更多相关文章

  1. 「TJOI / HEOI2016」字符串

    「TJOI / HEOI2016」字符串 题目描述 佳媛姐姐过生日的时候,她的小伙伴从某东上买了一个生日礼物.生日礼物放在一个神奇的箱子中.箱子外边写了一个长为 \(n\) 的字符串 \(s\),和 ...

  2. loj#2059. 「TJOI / HEOI2016」字符串 sam+线段树合并+倍增

    题意:给你一个子串,m次询问,每次给你abcd,问你子串sa-b的所有子串和子串sc-d的最长公共前缀是多长 题解:首先要求两个子串的最长公共前缀就是把反过来插入变成最长公共后缀,两个节点在paren ...

  3. 【LOJ】#2059. 「TJOI / HEOI2016」字符串

    题解 我们冷静一下,先画一棵后缀树 然后发现我们要给c和d这一段区间在[a,b]这一段开头的串里找lcp 而lcp呢,就是c点的祖先的到根的一段,假如这个祖先的子树里有[a,b - dis[u] + ...

  4. loj#2054. 「TJOI / HEOI2016」树

    题目链接 loj#2054. 「TJOI / HEOI2016」树 题解 每次标记覆盖整棵字数,子树维护对于标记深度取max dfs序+线段树维护一下 代码 #include<cstdio> ...

  5. AC日记——#2054. 「TJOI / HEOI2016」树

    #2054. 「TJOI / HEOI2016」树 思路: 线段树: 代码: #include <cstdio> #include <cstring> #include < ...

  6. AC日记——#2057. 「TJOI / HEOI2016」游戏 LOJ

    #2057. 「TJOI / HEOI2016」游戏 思路: 最大流: 代码: #include <cstdio> #include <cstring> #include &l ...

  7. loj #2055. 「TJOI / HEOI2016」排序

    #2055. 「TJOI / HEOI2016」排序   题目描述 在 2016 年,佳媛姐姐喜欢上了数字序列.因而他经常研究关于序列的一些奇奇怪怪的问题,现在他在研究一个难题,需要你来帮助他. 这个 ...

  8. loj2058 「TJOI / HEOI2016」求和 NTT

    loj2058 「TJOI / HEOI2016」求和 NTT 链接 loj 思路 \[S(i,j)=\frac{1}{j!}\sum\limits_{k=0}^{j}(-1)^{k}C_{j}^{k ...

  9. LOJ #2058「TJOI / HEOI2016」求和

    不错的推柿子题 LOJ #2058 题意:求$\sum\limits_{i=0}^n\sum\limits_{j=0}^nS(i,j)·2^j·j!$其中$ S(n,m)$是第二类斯特林数 $ Sol ...

随机推荐

  1. valueOf() 和 toString()

    valueOf():如果存在任意原始值,返回最适合该对象类型的原始值. toString():将该对象的原始值以字符串形式返回. 这两个方法一般是交由JS去隐式调用,以满足不同的运算情况.  举个栗子 ...

  2. Vue.js(2.x)之列表渲染(v-for/key)

    1.v-for是Vue里的循环语句,与其他语言的循环大同小异.首先得有需要循环且不为空的数组,循环的关键字为in或of. 需要索引时的写法: v-for里的in可以使用of代替: 还可以使用v-for ...

  3. jQuery中$(function(){})与(function($){})(jQuery)、$(document).ready(function(){})等的区别讲解

    1.(function($){...})(jQuery); (1).原理:       这实际上是匿名函数,如下: function(arg){...} 这就定义了一个匿名函数,参数为arg:而调用函 ...

  4. js addEventListener调用传参函数

    先看这段代码 function abc(key){ console.log(key); } for(let i=0;i<oInput.length;i++){ oInput[i].addEven ...

  5. hibernate笔记4--qbc查询

    Criteria:是一种完全面向对象的查询方式,Criteria查询也叫做qbc查询(query by Criteria).         查询全部,分页查询,统计查询,条件查询,排序查询,离线查询 ...

  6. 关于HTML中时间格式以及查询数据库的问题

    1.默认时间格式,加入属性dateFormate="yyyy-MM-dd" 2.设置默认值,value="2017-6-22" 3.在JavaScript中将获 ...

  7. centos7 初体验

    centos7 https://linux.cn/tag-RHCSA%7CRHCSA.html #/etc/sysconfig/network NETWORKING=yes GATEWAY=192.1 ...

  8. pta 编程题6 树的同构

    其它pta数据结构编程题请参见:pta 题目请参见:树的同构 因题目中左右子树是按照下标给出,因此用数组存放树是更好的方法. 判断两棵树是否同构:用递归的方法.如果当前两个结点都为空,则返回TRUE: ...

  9. java Vamei快速教程07 包

    作者:Vamei 出处:http://www.cnblogs.com/vamei 欢迎转载,也请保留这段声明.谢谢! 我们已经写了一些Java程序.之前的每个Java程序都被保存为一个文件,比如Tes ...

  10. 文件系统 - Linux 支持的文件系统类型

    NAME 文件系统 - Linux 支持的文件系统类型:minix, ext, ext2, xia, msdos, umsdos, vfat, proc, nfs, iso9660, hpfs, sy ...