栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

字符串哈希(模板)

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

字符串哈希(模板)

字符串匹配可以用KMP算法来做,但是KMP实在是太恶心了,对子字符串进行哈希找出子字符串,可以用哈希+滑动窗口的方法但每次求一个子字符串的哈希的复杂度都是O(N),比较慢。我们可以利用JDK对字符串的哈希原理,也就是KR算法,模板和介绍如下。
187. 重复的DNA序列

#define ull unsigned long long
class Solution {
public:
    string get(string &str, int len){
        int n = str.size();
        ull P = 131313;
        vector h(n+1, 0);
        vector p(n+1, 1);
        for(int i=1; i<=n; i++){
            h[i] = h[i-1]*P + (ull)(str[i-1]-'a');
            p[i] = p[i-1]*P;
        }
        unordered_set s;
        for(int i=1; i+len-1<=n; i++){
            int j = i+len-1;
            ull hash = h[j] - h[i-1]*p[j-i+1];
            if(s.find(hash)!=s.end())   return str.substr(i-1, j-i+1);
            s.insert(hash);
        }
        return "";
    }
};
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/678214.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号