当前位置: 首页 > news >正文

网站打不开了看装修案例的网站

网站打不开了,看装修案例的网站,网站建设提案,网站在哪里【题目链接】 http://www.spoj.pl/problems/PHRASES/ 【题目大意】 求在每个字符串中出现至少两次的最长的子串 【题解】 注意到这么几个关键点#xff1a;最长#xff0c;至少两次#xff0c;每个字符串。   首先对于最长这个条件#xff0c;我们可以想到二分答案…  【题目链接】 http://www.spoj.pl/problems/PHRASES/    【题目大意】   求在每个字符串中出现至少两次的最长的子串   【题解】   注意到这么几个关键点最长至少两次每个字符串。   首先对于最长这个条件我们可以想到二分答案   然后利用后缀数组所求得的三个数组判断是否满足条件。   其次是出现两次每次出现这个条件的时候   我们就应该要想到这是最大值最小值可以处理的   将出现在同一个字符串中的每个相同字符串的起始位置保存下来   如果最小值和最大值的差距超过二分长度L则表明在这个字符串中这个条件是可行的。   将所有的字符串通过拼接符连接在一起做一遍后缀数组   现在我们根据h数组将大于二分长度的前后后缀分为一组   每当存在分组中的后缀数量大于2*n   就说明这个字符串有可能是我们需要的答案那么对它进行检验   检验所有可能合法的字符串就可以完成对一个长度的判断了。   【代码】 #include cstdio #include cstring #include vector #include algorithm using namespace std; const int N1000010; int n,m,rank[N],sa[N],h[N],tmp[N],cnt[N],ans,a[N],s[N]; char str[N]; void suffixarray(int n,int m){int i,j,k;n;for(i0;i2*n5;i)rank[i]sa[i]h[i]tmp[i]0;for(i0;im;i)cnt[i]0;for(i0;in;i)cnt[rank[i]s[i]];for(i1;im;i)cnt[i]cnt[i-1];for(i0;in;i)sa[--cnt[rank[i]]]i;for(k1;kn;k1){for(i0;in;i){jsa[i]-k;if(j0)jn;tmp[cnt[rank[j]]]j;}sa[tmp[cnt[0]0]]j0;for(i1;in;i){if(rank[tmp[i]]!rank[tmp[i-1]]||rank[tmp[i]k]!rank[tmp[i-1]k])cnt[j]i;sa[tmp[i]]j;}memcpy(rank,sa,n*sizeof(int));memcpy(sa,tmp,n*sizeof(int));if(jn-1)break;}for(jrank[h[ik0]0];in-1;i,k)while(~ks[i]!s[sa[j-1]k])h[j]k--,jrank[sa[j]1]; }int first0,len[N],u,K; vectorint S[N]; int Min[15],Max[15]; bool check(int L){int cur-1;for(int i1;iu;i){if(h[i]L)S[cur].clear();S[cur].push_back(i);}for(int i0;icur;i){if(S[i].size()2*n){memset(Min,-1,sizeof(Min));memset(Max,-1,sizeof(Max));for(int j0;jS[i].size();j){int kS[i][j];int xupper_bound(a,an1,sa[k])-a-1;Min[x]Min[x]-1?sa[k]:min(Min[x],sa[k]);Max[x]Max[x]-1?sa[k]:max(Max[x],sa[k]);}bool flag1;for(int i0;in;i){if(Min[i]-1||Max[i]-Min[i]L){flag0;break;}}if(flag)return 1;}}return 0; }int T; int main(){scanf(%d,T);while(T--){scanf(%d,n);int tmp200; u0;for(int i0;in;i){scanf(%s,str);len[i]strlen(str);for(int j0;jlen[i];j)s[u](int)str[j];s[u]tmp;}tmp0; s[u]0; //注意处理完的字符串最后封零for(int i0;in;i){a[i]tmp;if(in)tmptmp(i0?len[i]:len[i]1);}suffixarray(u,310);int l1,r10000,ans0;while(lr){int mid(lr)1;if(check(mid))ansmid,lmid1;else rmid-1;}printf(%d\n,ans);}return 0; }转载于:https://www.cnblogs.com/forever97/p/PHRASES.html
http://www.huolong8.cn/news/183459/

相关文章:

  • 做纺织机械的网站域名新闻资讯网站怎么做
  • 宁波建设工程检测行业协会网站余姚网站建设开发
  • 网站建设优酷网站建设经费
  • 保定市城乡建设局官方网站外贸网站建设 泰州
  • 做年会的网站企业运营管理系统
  • 吴忠市建设局网站WordPress 站点图标链接
  • 返回json数据的网站豌豆荚app下载 官网
  • 中企动力和东莞朝阳做的网站对比wordpress封装易语言
  • 洛阳网站优化云闪付小程序开发平台
  • 修改网站域名网站主机空间
  • 深圳网站设计建设公司互联网建筑公司
  • 怎么向百度提交网站地图5g影视
  • 河北网站制作 网站开发网红自助下单网站
  • 手机发布会wordpress中文插件seo百度
  • 买源码做网站简单嘛浙江绿建建设计院网站
  • cms建站高校信息公开网站建设
  • 西安网站优化推广方案大理建设工程招聘信息网站
  • 网站 网络推广广东网站建设专业公司
  • 南通制作企业网站公众号开发需要哪些技术
  • 遵义市城乡建设局网站建e室内设计网app
  • 如何做视频网站市桥网站建设哪家好
  • 网站下载文件怎么做山西时代网站建设
  • 专业手机网站有哪些大悟网站制作
  • 做网站傻瓜软件strikingly建站工具
  • 小规模企业做网站wordpress基础开发教程 pdf
  • 对网站做打包备份处理我要做网店官网
  • 用oracle做网站数据库网站建设客户开发方法
  • 如何建一个购物网站怎么把店地址申请百度地图
  • 兰州新区城乡建设管理局网站海洋cms
  • 做外贸球衣用什么网站品牌设计得公司