/*
 求可重叠的至少重复K次的最长字串
 以1为下标起点,因为a[i]最大到1000000,所以要先离散一下
 二分长度len
 然后O(n)检验
 后看h[i]是否有连续的一段h[i]大于len的,并且h[i]连续的长度大于K则满足
 */
 #include<stdio.h>
 #include<string.h>
 #include<algorithm>
 using namespace std;
 ;
 int c[maxn],sa[maxn],t1[maxn],t2[maxn],n,m,K,tot,t[maxn],num[maxn],a[maxn],rank[maxn],height[maxn];

 bool cmp(int *r, int a, int b, int l){
     return r[a]==r[b] && r[a+l]==r[b+l];
 }

 void suffix(int *a, int n, int m){
     , *x=t1, *y=t2;
     ; i<=m; i++) c[i]=;
     ; i<=n; i++) c[x[i]=a[i]]++;
     ; i<=m; i++) c[i]+=c[i-];
     ; i--) sa[c[x[i]]--]=i;
     ; j<=n; j<<=){
         p=;
         ; i<=n; i++) y[++p]=i;
         ; i<=n; i++) if (sa[i]>j) y[++p]=sa[i]-j;
         ; i<=m; i++) c[i]=;
         ; i<=n; i++) c[x[y[i]]]++;
         ; i<=m; i++) c[i]+=c[i-];
         ; i--) sa[c[x[y[i]]]--]=y[i];
         swap(x,y); x[sa[]]=; p=;
         ; i<=n; i++)
             x[sa[i]]=cmp(y,sa[i-],sa[i],j)?p:++p;
         m=p; if (p>=n) break;
     }
     //for (int i=1; i<=n; i++) printf("%d\n", sa[i]);
 }

 void get_height(int *a){
     ,j;
     ; i<=n; i++) rank[sa[i]]=i;
     ; i<=n; i++){
         j=sa[rank[i]-];
         k?k--:;
         while (a[j+k]==a[i+k]) k++;
         height[rank[i]]=k;
     }
     //for (int i=1; i<=n; i++) printf("%d\n", height[i]);
 }

 int find(int x){
     , r=tot, ans;
     while (l<=r){
         ;
         ;
         ;
     }
     return ans;
 }

 bool check(int k){
     ;
     ; i<=n; i++){
         if (height[i]>=k) tot++;
         else{
             >=K) ;
             ;
         }
     }
     >=K) ; ;
 }

 int main(){
     scanf("%d%d", &n, &K);
     ; i<=n; i++) scanf("%d", &a[i]),num[i]=a[i];
     sort(num+,num++n); tot=;
     t[++tot]=num[];
     ; i<=n; i++)
         ])
             t[++tot]=num[i];
     ; i<=n; i++) a[i]=find(a[i]);
     suffix(a,n,n);
     get_height(a);
     ,r=n,ans;
     while (l<=r){
         ;
         ;
         ;
     }
     printf("%d\n", ans);
     ;
 } 

bzoj1717: [Usaco2006 Dec]Milk Patterns 产奶的模式(后缀数组+二分)的更多相关文章

  1. [bzoj1717][Usaco2006 Dec]Milk Patterns 产奶的模式——后缀数组

    Brief Description 给定一个字符串,求至少出现k次的最长重复子串. Algorithm Design 先二分答案,然后将后缀分成若干组.判断有没有一个组的后缀个数不小于k.如果有,那么 ...

  2. BZOJ 1717: [Usaco2006 Dec]Milk Patterns 产奶的模式 [后缀数组]

    1717: [Usaco2006 Dec]Milk Patterns 产奶的模式 Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 1017  Solved: ...

  3. 【BZOJ1717】[Usaco2006 Dec]Milk Patterns 产奶的模式 后缀数组

    [BZOJ1717][Usaco2006 Dec]Milk Patterns Description 农夫John发现他的奶牛产奶的质量一直在变动.经过细致的调查,他发现:虽然他不能预见明天产奶的质量 ...

  4. 【bzoj1717】[Usaco2006 Dec]Milk Patterns 产奶的模式 后缀数组+离散化

    题目描述 农夫John发现他的奶牛产奶的质量一直在变动.经过细致的调查,他发现:虽然他不能预见明天产奶的质量,但连续的若干天的质量有很多重叠.我们称之为一个“模式”. John的牛奶按质量可以被赋予一 ...

  5. bzoj1717: [Usaco2006 Dec]Milk Patterns 产奶的模式

    后缀数组+二分答案+离散化.(上次写的时候看数据小没离散化然后一直WA...写了lsj师兄的写法. #include<cstdio> #include<cstring> #in ...

  6. [bzoj1717][Usaco2006 Dec]Milk Patterns 产奶的模式_后缀数组_二分答案

    Milk Patterns 产奶的模式 bzoj-1717 Usaco-2006 Dec 题目大意:给定一个字符串,求最长的至少出现了$k$次的子串长度. 注释:$1\le n\le 2\cdot 1 ...

  7. [bzoj1717][Usaco2006 Dec]Milk Patterns 产奶的模式 (hash构造后缀数组,二分答案)

    以后似乎终于不用去学后缀数组的倍增搞法||DC3等blablaSXBK的方法了= = 定义(来自关于后缀数组的那篇国家集训队论文..) 后缀数组:后缀数组SA是一个一维数组,它保存1..n的某个排列S ...

  8. BZOJ 1717: [Usaco2006 Dec]Milk Patterns 产奶的模式( 二分答案 + 后缀数组 )

    二分答案m, 后缀数组求出height数组后分组来判断. ------------------------------------------------------------ #include&l ...

  9. BZOJ#1717:[Usaco2006 Dec]Milk Patterns 产奶的模式(后缀数组+单调队列)

    1717: [Usaco2006 Dec]Milk Patterns 产奶的模式 Description 农夫John发现他的奶牛产奶的质量一直在变动.经过细致的调查,他发现:虽然他不能预见明天产奶的 ...

随机推荐

  1. PhpStorm 8.x/9.x 快捷键设置/个性化设置,如何多项目共存?如何更换主题?

    1."自定义"常用快捷键(设置成跟Eclipse差不多) 按照路径:File -> Settings -> Appearance & Behavior -> ...

  2. PHP中的变量与常量详解

    几乎所有的编程语言都会涉及到变量和常量这两个概念,PHP也不例外.本节将介绍PHP语言中的变量和常量的应用方法. 一.什么是变量和常量 在程序执行的过程中,变量存储的值可以随时改变,而常量存储的值是不 ...

  3. HTTP API开发

    近期手上的安卓app需要用到自动更新的功能,想着怎么实现,看了下很多应用商店的sdk,觉得不太好,可能会收集用户隐私,于是想着自己实现一个http api后面自己可以实现自动更新,甚至广告推送的功能, ...

  4. TCP/IP四层模型

    转自:http://www.cnblogs.com/BlueTzar/articles/811160.html ISO制定的OSI参考模型的过于庞大.复杂招致了许多批评.与此对照,由技术人员自己开发的 ...

  5. TCP/IP三次握手和HTTP过程

    1.TCP连接 手机能够使用联网功能是因为手机底层实现了TCP/IP协议,可以使手机终端通过无线网络建立TCP连接.TCP协议可以对上层网络提供接口,使上层网络数据的传输建立在"无差别&qu ...

  6. nginx自动检测后台服务器健康状态

    转自http://www.iyunv.com/thread-38535-1-1.html 公司业务线上对后端节点的健康检查是通过nginx_upstream_check_module模块做的,这里我将 ...

  7. PHP多进程编程实例

    这篇文章主要介绍了PHP多进程编程实例,本文讲解的是在Linux下实现PHP多进程编程,需要的朋友可以参考下 羡慕火影忍者里鸣人的影分身么?没错,PHP程序是可以开动影分身的!想完成任务,又觉得一个进 ...

  8. UIPickerView选择器的使用方法

    UIPickerView是选择列表内容的控件 使用方法与UITableView类似 都需要用array传入数据 用Delegate DataSource中的代理方法实现各种显示功能 @interfac ...

  9. ASM:《X86汇编语言-从实模式到保护模式》第9章:实模式下中断机制和实时时钟

    中断是处理器一个非常重要的工作机制.第9章是讲中断在实模式下如何工作,第17章是讲中断在保护模式下如何工作. ★PART1:外部硬件中断 外部硬件中断是通过两个信号线引入处理器内部的,这两条线分别叫N ...

  10. DOM动画效果的基础入门2

    一.动画效果 Transform字面上就是变形,改变的意思,在css3中transform主要包括以下几种: 选转 rotate,扭曲 skew 缩放 scale 和移动translate 以及矩形变 ...