字符串哈希

用处:对于一个给定的字符串,频繁查找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;
}
相关推荐
平凡但不平庸的码农7 小时前
Go Slice 详解
算法·golang
炸膛坦客10 小时前
嵌入式 - 数据结构与算法:(1-7)数据结构 - 顺序表和链表的对比
数据结构·链表
Jasmine_llq10 小时前
《B3867 [GESP202309 三级] 小杨的储蓄》
算法·循环遍历·数组累加(模拟)·索引定位·顺序输出
啦啦啦_999910 小时前
案例之 逻辑回归_电信用户流失预测
算法·机器学习·逻辑回归
风筝在晴天搁浅11 小时前
快手/字节 CodeTop LeetCode 415.字符串相加
算法·leetcode
hoiii18711 小时前
基于栅格法的机器人工作空间划分系统
数据结构·机器人
DragonnAi11 小时前
猫咪如厕检测与分类识别系统系列【十四】 项目结构重新整理-即将开源完整算法
算法·开源
机器视觉_Explorer11 小时前
【halcon】编程技巧:鼠标擦除
图像处理·人工智能·深度学习·算法·视觉检测
灵智实验室12 小时前
PX4状态估计技术EKF2详解(二):EKF2 误差状态动力学与协方差传播
算法·无人机·px 4
米粒113 小时前
力扣算法刷题 Day 64 Floyd算法 & A* 算法 & 总结篇
算法·leetcode·职场和发展