hdu1403 Longest Common Substring
地址:http://acm.split.hdu.edu.cn/showproblem.php?pid=1403
题目:
Longest Common Substring
Time Limit: 8000/4000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 6296 Accepted Submission(s): 2249
For example:
str1 = banana
str2 = cianaic
So the Longest Common Substring is "ana", and the length is 3.
Process to the end of file.
cianaic
思路:把两个字符串连接起来,中间用一个没出现过的字符隔开。
然后二分答案,二分check时对height进行分组,判断height值全大于x的组内 是否同时包含两个字符串的子串
- #include <cstdlib>
- #include <cstring>
- #include <cstdio>
- #include <algorithm>
- const int N = ;
- int sa[N],s[N],wa[N], wb[N], ws[N], wv[N];
- int rank[N], height[N];
- bool cmp(int r[], int a, int b, int l)
- {
- return r[a] == r[b] && r[a+l] == r[b+l];
- }
- void da(int r[], int sa[], int n, int m)
- {
- int i, j, p, *x = wa, *y = wb;
- for (i = ; i < m; ++i) ws[i] = ;
- for (i = ; i < n; ++i) ws[x[i]=r[i]]++;
- for (i = ; i < m; ++i) ws[i] += ws[i-];
- for (i = n-; i >= ; --i) sa[--ws[x[i]]] = i;
- for (j = , p = ; p < n; j *= , m = p)
- {
- for (p = , i = n - j; i < n; ++i) y[p++] = i;
- for (i = ; i < n; ++i) if (sa[i] >= j) y[p++] = sa[i] - j;
- for (i = ; i < n; ++i) wv[i] = x[y[i]];
- for (i = ; i < m; ++i) ws[i] = ;
- for (i = ; i < n; ++i) ws[wv[i]]++;
- for (i = ; i < m; ++i) ws[i] += ws[i-];
- for (i = n-; i >= ; --i) sa[--ws[wv[i]]] = y[i];
- for (std::swap(x, y), p = , x[sa[]] = , i = ; i < n; ++i)
- x[sa[i]] = cmp(y, sa[i-], sa[i], j) ? p- : p++;
- }
- }
- void calheight(int r[], int sa[], int n)
- {
- int i, j, k = ;
- for (i = ; i <= n; ++i) rank[sa[i]] = i;
- for (i = ; i < n; height[rank[i++]] = k)
- for (k?k--:, j = sa[rank[i]-]; r[i+k] == r[j+k]; k++);
- }
- bool check(int la,int lb,int lc,int x)
- {
- int m1=,m2=;
- if(sa[]<la)m1=;
- if(sa[]>la)m2=;
- for(int i=;i<=lc;i++)
- {
- if(height[i]<x)
- {
- if(m1&&m2)
- return ;
- m1=m2=;
- }
- if(sa[i]<la)m1=;
- if(sa[i]>la)m2=;
- }
- return m1&&m2;
- }
- char ss[N];
- int main()
- {
- while(scanf("%s",ss)==)
- {
- int la=strlen(ss),lb,n=;
- for(int i=;i<la;i++)
- s[n++]=ss[i]-'a'+;
- s[n++]=;
- scanf("%s",ss);
- lb=strlen(ss);
- for(int i=;i<lb;i++)
- s[n++]=ss[i]-'a'+;
- s[n]=;
- da(s,sa,n+,);
- calheight(s,sa,n);
- int l=,r=la,ans=;
- while(l<=r)
- {
- int mid=l+r>>;
- if(check(la,lb,n,mid))
- ans=mid,l=mid+;
- else
- r=mid-;
- }
- printf("%d\n",ans);
- }
- return ;
- }
hdu1403 Longest Common Substring的更多相关文章
- [HDU1403]Longest Common Substring(后缀数组)
传送门 求两个串的公共子串(注意,这个公共子串是连续的一段) 把两个串连在一起,中间再加上一个原字符串中不存在的字符,避免过度匹配. 求一遍height,再从height中找满足条件的最大值即可. 为 ...
- HDU 1403 Longest Common Substring(后缀自动机——附讲解 or 后缀数组)
Description Given two strings, you have to tell the length of the Longest Common Substring of them. ...
- SPOJ LCS2 - Longest Common Substring II
LCS2 - Longest Common Substring II A string is finite sequence of characters over a non-empty finite ...
- LintCode Longest Common Substring
原题链接在这里:http://www.lintcode.com/en/problem/longest-common-substring/# 题目: Given two strings, find th ...
- Longest Common Substring
Given two strings, find the longest common substring. Return the length of it. Example Given A = &qu ...
- 【SPOJ】1812. Longest Common Substring II(后缀自动机)
http://www.spoj.com/problems/LCS2/ 发现了我原来对sam的理解的一个坑233 本题容易看出就是将所有匹配长度记录在状态上然后取min后再对所有状态取max. 但是不要 ...
- hdu 1403 Longest Common Substring(最长公共子字符串)(后缀数组)
http://acm.hdu.edu.cn/showproblem.php?pid=1403 Longest Common Substring Time Limit: 8000/4000 MS (Ja ...
- 后缀自动机(SAM):SPOJ Longest Common Substring II
Longest Common Substring II Time Limit: 2000ms Memory Limit: 262144KB A string is finite sequence of ...
- 后缀自动机(SAM) :SPOJ LCS - Longest Common Substring
LCS - Longest Common Substring no tags A string is finite sequence of characters over a non-empty f ...
随机推荐
- spring配置文件头部配置解析
http://blog.csdn.net/f_639584391/article/details/50167321
- 分页技巧_测试并继续改进分页用的QueryHelper辅助对象
分页技巧_测试并继续改进分页用的QueryHelper辅助对象 QueryHelper.java /** * 用于辅助拼接HQL语句 */ public class QueryHelper { pri ...
- ios开发--图文混排(富文本)
最近准备接一个编辑类的app,所以就查了下相关的功能,并自己试验了下: /** iOS 6之前:CoreText,纯C语言,极其蛋疼 iOS 6开始:NSAttributedString,简单易用 i ...
- SqlSession接口和Executor
mybatis框架在操作数据的时候,离不开SqlSession接口实例类的作用.可以说SqlSession接口实例是开发过程中打交道最多的一个类.即是DefaultSqlSession类.如果笔者记得 ...
- JSP小例子——以Model1的思想实现用户登录小例子(不涉及DB操作)
Model1简介现在比较流行的就是Model1和Model2,这里介绍Model1.在Model1模型出现前,整个Web应用的情况是:几乎全部由JSP页面组成,JSP页面接受处理客户端请求,对请求处理 ...
- git与sourceTree
Window:http://my.oschina.net/lunqi/blog/500881?fromerr=bzaPk1Lx MAC:http://www.ithao123.cn/content-8 ...
- java框架---->RxJava的使用(一)
RxJava是响应式程序设计的一种实现.在响应式程序设计中,当数据到达的时候,消费者做出响应.响应式编程可以将事件传递给注册了的observer.今天我们就来学习一下rxJava,并分析一下它源码感受 ...
- PHPStorm自动压缩YUI Compressor配置
File---Settings...---Tools---File Watchers 点击右边加号,添加: 在弹出窗中 主要是Program的内容,点击后面的省略点,默认目录下回出现yuicompre ...
- 【POJ1275】Cashier Employment 差分约束
[POJ1275]Cashier Employment 题意: 超市经历已经提供一天里每一小时需要出纳员的最少数量————R(0),R(1),...,R(23).R(0)表示从午夜到凌晨1:00所需要 ...
- jquery如何把一个html元素替换成另外一个html元素?
1.replaceWith( ) 使用括号内的内容替换所选择的内容. $("#div").replaceWith("<p id=&qu ...