字符串哈希

用处:对于一个给定的字符串,频繁查找l到 r区间和l1到r1区间的字符串是否一致。

思路:

首先利用一个前缀和,存放在h[N]中。h[i]表示从第一个字符到第i个字符的字符串所对应的一个哈希值,该哈希值参考了进制的做法,因此用p进制表示,p是一个具体的数。

然后,根据前缀和的公式,从l到r的哈希值就和h[r],h[l-1]有关,而h中存放的是前缀和,因此要把h[l-1]左移r-1-(l-1-1)位置,即乘以p的(r-1-l+1+1)次方,再相减。

此处规定p=131或者13331,取模规定是2的64次方,这样哈希冲突是基本没有的,也就是说这个做法是忽略哈希冲突的。

#include<iostream>
#include<cstring>

typedef unsigned long long ULL;
const int N=100010;
int p=131;//用于进位的数
ULL pp[N];  
ULL h[N];
char str[N];

int get(int l,int r)
{
    return h[r]-h[l-1]*pp[r-l+1];
}
int main()
{   
    int n,m;
    scanf("%d%d%s",&n,&m,str);
    
    pp[0]=1;
    for(int i=1;i<=n;i++)
    {
        pp[i]=pp[i-1]*p;
        h[i]=h[i-1]*p+str[i-1];
    }
    
    while(m--)
    {
        int l1,r1,l2,r2;
        scanf("%d%d%d%d",&l1,&r1,&l2,&r2);
        if(get(l1,r1)==get(l2,r2))
        puts("Yes");
        else
        puts("No");
    }
    return 0;
}
相关推荐
逝去的秋风5 分钟前
【代码随想录训练营第42期 Day60打卡 - 图论Part10 - Bellman_ford算法系列运用
算法·图论·bellman_ford算法
running up that hill11 分钟前
Java中List、ArrayList与顺序表
java·开发语言·数据结构
请站在我身后32 分钟前
读论文《OmniGen: Unified Image Generation》
人工智能·深度学习·算法·语言模型·transformer
阿华的代码王国35 分钟前
【JavaEE】——单例模式引起的多线程安全问题:“饿汉/懒汉”模式,及解决思路和方法(面试高频)
java·数据结构·单例模式·java-ee
万物纵横科技40 分钟前
AI视觉算法盒是什么?如何智能化升级网络摄像机,守护全方位安全
算法·ai
咖啡里的茶i43 分钟前
C++之Person类
开发语言·c++·算法
每天敲200行代码44 分钟前
C++ 红黑树
开发语言·c++·算法
Kalika0-01 小时前
闰年判断-C语言
c语言·开发语言·算法
一只特立独行的猪6111 小时前
算法记录——树
java·数据结构·算法
zyh200504301 小时前
Redis数据结构之list列表
数据结构·数据库·redis