题解 | #公共子串计算#

公共子串计算

http://www.nowcoder.com/questionTerminal/98dc82c094e043ccb7e0570e5342dd1b

看了下题解里好像没太有人用这个,二分法+滚动哈希

P,Q=131,2**64
s1=input()
s2=input()
n1,n2=len(s1),len(s2)
def hsm(mid):
    seen=set()
    K=P**mid%Q
    pre=0
    for i in range(mid):
        pre=(P*pre+ord(s1[i]))%Q
    seen.add(pre)
    for i in range(mid,n1):
        pre=(P*pre+ord(s1[i])-ord(s1[i-mid])*K)%Q
        seen.add(pre)
    pre=0
    for i in range(mid):
        pre=(P*pre+ord(s2[i]))%Q
    if pre in seen:
        return True
    for i in range(mid,n2):
        pre=(P*pre+ord(s2[i])-ord(s2[i-mid])*K)%Q
        if pre in seen:
            return True
    return False        
l,r=0,min(n1,n2)
ans=0
while l<r:
    mid=1+(l+r)//2
    if hsm(mid):
        l=mid
        ans=mid
    else:
        r=mid-1
print(ans)

    

全部评论

相关推荐

青春运维少年不会梦到...:实习大王
点赞 评论 收藏
分享
09-18 20:41
阿里巴巴_后端
要个offer怎么这...:哈哈哈哈哈哈,我也拿了0x10000000个offer,秋招温啦啦啦,好开心
我的秋招日记
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务