博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
POJ 1743 Musical Theme 后缀数组 不可重叠最长反复子串
阅读量:5327 次
发布时间:2019-06-14

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

二分长度k 长度大于等于k的分成一组 每组sa最大的和最小的距离大于k 说明可行

#include 
#include
#include
using namespace std;const int maxn = 20010;int s[maxn];int sa[maxn];int t[maxn], t2[maxn], c[maxn];int rank[maxn], height[maxn];void build_sa(int m, int n){ int i, *x = t, *y = t2; for(i = 0; i < m; i++) c[i] = 0; for(i = 0; i < n; i++) c[x[i] = s[i]]++; for(i = 1; i < m; i++) c[i] += c[i-1]; for(i = n-1; i >= 0; i--) sa[--c[x[i]]] = i; for(int k = 1; k <= n; k <<= 1) { int p = 0; for(i = n-k; i < n; i++) y[p++] = i; for(i = 0; i < n; i++) if(sa[i] >= k) y[p++] = sa[i] - k; for(i = 0; i < m; i++) c[i] = 0; for(i = 0; i < n; i++) c[x[y[i]]]++; for(i = 0; i < m; i++) c[i]+= c[i-1]; for(i = n-1; i >= 0; i--) sa[--c[x[y[i]]]] = y[i]; swap(x, y); p = 1; x[sa[0]] = 0; for(i = 1; i < n; i++) x[sa[i]] = y[sa[i-1]] == y[sa[i]] && y[sa[i-1]+k] == y[sa[i]+k] ? p-1 : p++; if(p >= n) break; m = p; }}void getHeight(int n){ int k = 0; for(int i = 0; i <= n; i++) rank[sa[i]] = i; for(int i = 0; i < n; i++) { if(k) k--; int j = sa[rank[i]-1]; while(s[i+k] == s[j+k]) k++; height[rank[i]] = k; }}bool ok(int n, int k){ int ans1 = sa[1], ans2 = sa[1]; for(int i = 2; i <= n; i++) { if(height[i] < k) { ans1 = ans2 = sa[i]; } else { ans1 = max(ans1, sa[i]); ans2 = min(ans2, sa[i]); if(ans1-ans2 > k) return true; } } return false;}int main(){ int n; while(scanf("%d", &n) && n) { for(int i = 0; i < n; i++) scanf("%d", &s[i]); n--; for(int i = 0; i < n; i++) s[i] = s[i+1] - s[i] + 90; s[n] = 0; build_sa(200, n+1); getHeight(n); int l = 4, r = n+1; int ans = -1; while(l <= r) { int m = (l+r) >> 1; if(ok(n, m)) { l = m+1; ans = m; } else r = m-1; } printf("%d\n", ans+1); } return 0;}

转载于:https://www.cnblogs.com/gcczhongduan/p/5183452.html

你可能感兴趣的文章
css 跳转电脑分辨率
查看>>
行为型模型 中介者模式
查看>>
Web服务器的原理
查看>>
小强升职计读书笔记
查看>>
Oracle数据库端分页SQL语句
查看>>
常用的107条Javascript
查看>>
web开发快速提高工作效率的一些资源
查看>>
echarts同一页面四个图表切换的js数据交互
查看>>
cf 二分图
查看>>
ResultSet用法集锦
查看>>
我们终将死去,这难道不够美好吗?
查看>>
Python 从入门到精通 全程最佳实现梳理
查看>>
HADOOP高可用机制
查看>>
用工厂流水线的方式来理解 RxJava 的概念
查看>>
Redis集群迁移
查看>>
【旧文章搬运】PsVoid中IrpCreateFile函数在Win7下蓝屏BUG分析及解决
查看>>
[Git] Squash all of my commits into a single one and merge into master
查看>>
[Bootstrap] 8. 'Collapse', data-target, data-toggle & data-parent
查看>>
Docker和CI/CD实战
查看>>
架构师:成为架构师可能会面临的问题
查看>>