偷懒直接把bzoj的网页内容ctrlcv过来了

2806: [Ctsc2012]Cheat

Time Limit: 20 Sec  Memory Limit: 256 MB
Submit: 1943  Solved: 1004
[Submit][Status][Discuss]

Description

Input

第一行两个整数N,M表示待检查的作文数量,和小强的标准作文库
的行数
接下来M行的01串,表示标准作文库
接下来N行的01串,表示N篇作文

Output

N行,每行一个整数,表示这篇作文的Lo 值。

Sample Input

1 2
10110
000001110
1011001100

Sample Output

4

HINT

输入文件不超过1100000字节

注意:题目有改动,可识别的长度不小于90%即可,而不是大于90%


所谓少于$1.1*10^6$就是总输入字符数少于这个数...

果然CTSC出的题水平够高

专门爆踩SAM只学了板子不懂各个元素含义和应用的菜鸡(像我这样的就是了)

随便把模式串扔进广义SAM里

答案L0具有单调性

所以二分答案

接下来考虑$O(n)$求出最长匹配长度

$O(n)$的话...只能dp了啊

在SAM上跑字符串匹配求出每一位的最长向前匹配长度$f[i]$

用$dp[i]$表示到i位置匹配了多少字符

之后有dp方程

$dp[i]=max(dp[i-1],max(dp[j=(i-f[i]) to (i-L0)]+i-j))$

对于$dp[j]-j$,$O(n^2)$单调队列优化变成$O(n)$

本题完结

 #include<cstdio>
 #include<cstring>
 #include<queue>
 using std::queue;
 ;
 char sin[N];
 int nn,nm,n;
 template<typename tp>tp max(tp a,tp b){return a>b?a:b;}

 struct sam
 {
     ],len,pre;
 }s[N<<];

 struct Sakuya_Brando
 {
     int size,fin;
     Sakuya_Brando(){size=;}
     void insert(int ch)
     {
         int npx,npy,lpx,lpy;
         if(s[fin].tranc[ch])
         {
             lpx=fin,lpy=s[fin].tranc[ch];
             ) fin=lpy;
             else
             {
                 npy=++size;
                 s[npy]=s[lpy];
                 s[npy].len=s[lpx].len+;
                 s[lpy].pre=npy;
                 while(s[lpx].tranc[ch]==lpy)
                 {
                     s[lpx].tranc[ch]=npy;
                     lpx=s[lpx].pre;
                 }
                 fin=npy;
             }
             return;
         }
         npx=++size;
         s[npx].len=s[fin].len+;
         for(lpx=fin;lpx&&!s[lpx].tranc[ch];lpx=s[lpx].pre) s[lpx].tranc[ch]=npx;
         ;
         else
         {
             lpy=s[lpx].tranc[ch];
             ) s[npx].pre=lpy;
             else
             {
                 npy=++size;
                 s[npy]=s[lpy];
                 s[npy].len=s[lpx].len+;
                 s[lpy].pre=s[npx].pre=npy;
                 while(s[lpx].tranc[ch]==lpy)
                 {
                     s[lpx].tranc[ch]=npy;
                     lpx=s[lpx].pre;
                 }
             }
         }
         fin=npx;
     }
     void ins(char *str,int len)
     {
         fin=;
         len=strlen(str);
         ;i<len;i++) insert(str[i]-');
     }
 }sakuya;

 int f[N];
 int dp[N];
 struct stack
 {
     int v,id;
     stack(){}
     stack(int a,int b){v=a,id=b;}
 }sta[N];
 int he,ta;

 void bao0(char *str,int len)
 {
     ,tmp=;
     ;i<len;i++)
     {
         ';
         if(s[px].tranc[ch]) tmp++,px=s[px].tranc[ch];
         else
         {
             while(px&&!s[px].tranc[ch]) px=s[px].pre;
             ,px=;
             ,px=s[px].tranc[ch];
         }
         f[i]=tmp;
     }
 }
 void noi(char *str,int len)
 {
     ;i<len;i++) f[i]=;
 }
 bool check(char *str,int ll,int len)
 {
     he=,ta=;
     ;
     ;j<len;i++,j++)
     {
         dp[i]=dp[i-];
         while(he<=ta&&sta[he].id<i-f[j]) he++;
         while(he<=ta&&sta[ta].v<=dp[i-ll]-(i-ll)) ta--;
         sta[++ta]=stack(dp[i-ll]-(i-ll),i-ll);
         while(he<=ta&&sta[he].id<i-f[j]) he++;
         if(he<=ta) dp[i]=max(dp[i],i+sta[he].v);
     }
     mxx=dp[len];
     ;i<=len;i++) dp[i]=;
     >=len*) ;
     ;
 }

 int main()
 {
     scanf("%d%d",&nn,&nm);
     ;i<=nm;i++)
     {
         scanf("%s",sin);
         n=strlen(sin);
         sakuya.ins(sin,n);
     }
     ;i<=nn;i++)
     {
         scanf("%s",sin);
         n=strlen(sin);
         bao0(sin,n);
         ,r0=n;
         while(l0<r0)
         {
             )>>;
             if(check(sin,mid,n)) l0=mid;
             ;
         }
         noi(sin,n);
         printf("%d\n",l0);
     }
     ;
 }

[bzoj2806][Ctsc2012]Cheat(后缀自动机(SAM)+二分答案+单调队列优化dp)的更多相关文章

  1. [CTSC2012]熟悉的文章(广义后缀自动机+二分答案+单调队列优化DP)

    我们对作文库建出广义后缀自动机.考虑用\(SAM\)处理出来一个数组\(mx[i]\),表示从作文的第\(i\)个位置向左最远在作文库中出现的子串的长度.这个东西可以在\(SAM\)上跑\(trans ...

  2. P3957 跳房子(二分答案+单调队列优化DP)

    题目链接:https://www.luogu.org/contestnew/show/4468 题目大意:跳房子,也叫跳飞机,是一种世界性的儿童游戏,也是中国民间传统的体育游戏之一. 跳房子的游戏规则 ...

  3. 洛谷 P3957 跳房子 —— 二分答案+单调队列优化DP

    题目:https://www.luogu.org/problemnew/show/P3957 先二分一个 g,然后判断: 由于转移的范围是一个区间,也就是滑动窗口,所以单调队列优化: 可以先令队尾为 ...

  4. [NOIP2017普及组]跳房子(二分,单调队列优化dp)

    [NOIP2017普及组]跳房子 题目描述 跳房子,也叫跳飞机,是一种世界性的儿童游戏,也是中国民间传统的体育游戏之一. 跳房子的游戏规则如下: 在地面上确定一个起点,然后在起点右侧画 nn 个格子, ...

  5. 【BZOJ2806】Cheat(后缀自动机,二分答案,动态规划,单调队列)

    [BZOJ2806]Cheat(后缀自动机,二分答案,动态规划,单调队列) 题面 BZOJ 洛谷 题解 很有趣的一道题啊 对于在所有的串上面进行匹配? 很明显的后缀自动机 所以先构建出广义后缀自动机 ...

  6. BZOJ_3316_JC loves Mkk_ 二分答案 + 单调队列

    BZOJ_3316_JC loves Mkk_ 二分答案 + 单调队列 题意: 分析: 拆成链,二分答案,奇偶两个单调队列维护最大子段和,记录方案. 代码: #include <cstdio&g ...

  7. 2018.09.26洛谷P3957 跳房子(二分+单调队列优化dp)

    传送门 表示去年考普及组的时候失了智,现在看来并不是很难啊. 直接二分答案然后单调队列优化dp检验就行了. 注意入队和出队的条件. 代码: #include<bits/stdc++.h> ...

  8. BZOJ2806 [Ctsc2012]Cheat 【后缀自动机 + 二分 + 单调队列优化DP】

    题目 输入格式 第一行两个整数N,M表示待检查的作文数量,和小强的标准作文库 的行数 接下来M行的01串,表示标准作文库 接下来N行的01串,表示N篇作文 输出格式 N行,每行一个整数,表示这篇作文的 ...

  9. BZOJ 2806: [Ctsc2012]Cheat [广义后缀自动机 单调队列优化DP 二分]

    2806: [Ctsc2012]Cheat 题意: 多个主串和多个询问串,每次询问将询问串分成多个连续子串,如果一个子串长度>=L且在主串中出现过就是熟悉的 如果熟悉的字符串长度>=询问串 ...

随机推荐

  1. 将json文件转换成insert语句的sql文件

    引入是要的maven依赖: <!-- https://mvnrepository.com/artifact/com.google.code.gson/gson --> <depend ...

  2. 洛谷P4141消失之物(背包经典题)——Chemist

    题目地址:https://www.luogu.org/problemnew/show/P4141 分析:这题当然可以直接暴力枚举去掉哪一个物品,然后每次暴力跑一遍背包,时间复杂度为O(m*n^2),显 ...

  3. 【原创】《从0开始学Elasticsearch》—初识Elasticsearch

    目录 1. Elasticsearch 是什么2. Elasticsearch 中基本概念3. Elasticsearch 安装4. 访问 Elasticsearch 1. Elasticsearch ...

  4. 如何在tomcat部署项目(用ip访问)

    找了好长时间的错误,server.xml中一点错误也没有,但就是访问不到,最终发现就是服务器没有开放80端口的缘故. 服务器是Windows系统 1.控制面板=>系统和安全=>Window ...

  5. IDEA安装使用

    下载地址: https://www.jetbrains.com/idea/download/previous.html 这里我下载的是:2016.3.8版本的 安装: 安装成功后,需要秘钥的话,在 h ...

  6. linux下安装mysql5.7.21

    下载 wget https://dev.mysql.com/get/Downloads/MySQL-5.7/mysql-5.7.21-linux-glibc2.12-x86_64.tar.gz 解压 ...

  7. provider模式

    最近看代码有所感想吧.当底层API,发生变化时,可以使用Provider模式.既然是模式就一定的股则. 1.该模式对原有接口的封装. 2.该模式实现对API的封装,不显示细节,从而取消依赖关系. 3. ...

  8. Petri网的工具

    需要寻找 Petri 网的工具的朋友可以在 http://www.informatik.uni-hamburg.de/TGI/PetriNets/tools/complete_db.html 里面找一 ...

  9. Java MVC框架性能比较

    Java MVC框架性能比较 - by zvane 现在各种MVC框架很多,各框架的优缺点网络上也有很多的参考文章,但介绍各框架性能方面差别的文章却不多,本人在项目开发中,感觉到采用了struts2框 ...

  10. IE盒模型和标准w3c盒模型

    Margin(外边距) - 清除边框外的区域,外边距是透明的.Border(边框) - 围绕在内边距和内容外的边框.Padding(内边距) - 清除内容周围的区域,内边距是透明的.Content(内 ...