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

做网页的软件html百度seo搜索排名

做网页的软件html,百度seo搜索排名,网站建设需要的技术,网站上传百度多久收录【题目链接】 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.zqtcl.cn/news/816437/

相关文章:

  • 学计算机的做网站的叫什么工作wordpress商用收费不
  • 青岛网站建设谁家好一些网页微信怎么登陆
  • 企业网站seo优做网站的旅行社
  • 十大免费自助建站上传网站到空间
  • 深圳企业做网站简约个人网站
  • 茂名放心营销网站开发网站怎么做app
  • php语言 网站建设专业的外贸网站建设公司价格
  • 看英语做游戏的网站wordpress与微信对接
  • 企业网站打不开了看守所加强自身网站建设工作
  • 长汀网站建设做电池的有哪些网站
  • 做软件常用的网站厦门建设局地址
  • 沭阳三剑客做网站科技 公司 响应式 网站
  • 深圳网站建设培训哪家好曲阜网架公司
  • wordpress建立网站实例贵阳网站开发谁家做的好
  • 百度网站推广怎么收费中国科技成果
  • 枣庄企业网站建设wordpress 评论群发
  • 网站视觉设计方案视频制作素材
  • 哪个网站专做民宿wordpress 主题教程
  • 网站后台 设计北京海淀区官网
  • 公司官网网站建设想法wordpress oss
  • 如何自己创建网站招聘网站代理
  • 手机网页视频提取工具seo网站是什么
  • seo网站优化公司龙岩网站设计一般要多久
  • 江苏自助建站系统哪家好go语言网站开发
  • 建设网站 注册与登陆wordpress产品上传
  • 河北省住房与建设厅网站陶瓷刀具网站策划书
  • 大型商城网站建设方案程序外包
  • 邵阳网站建设制作电子商务网站开发软件
  • 怎样推广网站平台树莓派 wordpress mysql
  • 互联网公司网站建设wordpress发文章设置文字大小