博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
POJ 3261 Milk Patterns (后缀数组,求可重叠的k次最长重复子串)
阅读量:6583 次
发布时间:2019-06-24

本文共 2573 字,大约阅读时间需要 8 分钟。

Milk Patterns
Time Limit: 5000MS   Memory Limit: 65536K
Total Submissions: 16742   Accepted: 7390
Case Time Limit: 2000MS

Description

Farmer John has noticed that the quality of milk given by his cows varies from day to day. On further investigation, he discovered that although he can't predict the quality of milk from one day to the next, there are some regular patterns in the daily milk quality.

To perform a rigorous study, he has invented a complex classification scheme by which each milk sample is recorded as an integer between 0 and 1,000,000 inclusive, and has recorded data from a single cow over N (1 ≤ N ≤ 20,000) days. He wishes to find the longest pattern of samples which repeats identically at least K (2 ≤ KN) times. This may include overlapping patterns -- 1 2 3 2 3 2 3 1 repeats 2 3 2 3 twice, for example.

Help Farmer John by finding the longest repeating subsequence in the sequence of samples. It is guaranteed that at least one subsequence is repeated at least K times.

Input

Line 1: Two space-separated integers:
N and
K
Lines 2..
N+1:
N integers, one per line, the quality of the milk on day
i appears on the
ith line.

Output

Line 1: One integer, the length of the longest pattern which occurs at least
K times

Sample Input

8 212323231

Sample Output

4
/*************************************************************************    > File Name: poj3261.cpp    > Author: LyuCheng    > Created Time: 2017-11-30 17:04    > Description: 询问最长可重复k次的串的长度,求出height数组的值,求连续            的lca是不是大于k如果大于k那么就满足条件 ************************************************************************/#include 
#include
#include
#define maxn 23456using namespace std;struct SuffixArray{ int s[maxn]; int sa[maxn]; int rank[maxn]; int height[maxn]; int t1[maxn],t2[maxn],c[maxn],n; void build_sa(int m){ int i,*x=t1,*y=t2; for(i=0;i
=0;i--) sa[--c[x[i]]]=i; for(int k=1;k<=n;k<<=1){ int p=0; for(i=n-k;i
=k) y[p++]=sa[i]-k; for(i=0;i
=0;i--) sa[--c[x[y[i]]]]=y[i]; swap(x,y); p=1,x[sa[0]]=0; for(i=1;i
=n) break; m=p; } } void build_height(){ int i,j,k=0; for(i=0;i
=pos){ s++; if(s>=k) return true; }else{ s=1; } } return false;}inline void init(){ maxs=-1; ans=0;}int main(){ while(scanf("%d%d",&n,&k)!=EOF){ init(); sa.n=n; for(int i=0;i
>1; if(ok(m)==true){ ans=m; l=m+1; }else{ r=m-1; } } printf("%d\n",ans); } return 0;}

 

转载于:https://www.cnblogs.com/wuwangchuxin0924/p/7929954.html

你可能感兴趣的文章
Cassandra – 理解关键概念和数据模型
查看>>
进阶PHP需要注意的一些点
查看>>
Java反射讲解-实例(1)
查看>>
Docker中安装oracle 11.2.0.4
查看>>
Uncompressing Linux... done, booting the kernel
查看>>
k8s-之无头服务初体验
查看>>
神码设备,实验配置案例(一)
查看>>
webgl学习笔记四
查看>>
【2012年给力作品】通用U盘装系统制作工具 V2.0 万能版 火热发布中……
查看>>
Spring Bean注册解析(二)
查看>>
python利用utf-8编码判断中文字符
查看>>
简单的jquery代码实现表单验证
查看>>
递归算法简单介绍
查看>>
ORA-00119 LOCAL_LISTENER错误,LRM-00109
查看>>
matlab-基础 abs 获取字符的ASCII码
查看>>
Jquery easyUI 使用资料汇总
查看>>
vue 源码分析资料
查看>>
网络基础知识--网络架构及OSI七层协议
查看>>
Gradle初体验
查看>>
设置div边距
查看>>