当前位置: 首页 > news >正文

字符串哈希

用处:对于一个给定的字符串,频繁查找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");elseputs("No");}return 0;
}


http://www.mrgr.cn/news/35473.html

相关文章:

  • 2-102基于matlab的蒙特卡洛仿真
  • 考研数据结构——C语言实现小顶堆
  • SpringBoot基础知识
  • string 的介绍及使用
  • C++语言桌面应用开发GTK3 Gtkmm3 Glade
  • 在Java中如何利用ClassLoader动态加密、解密Class文件
  • 面经宝典【1】-拼多多
  • 插入、更新与删除MySQL记录
  • Python 入门教程(7)面向对象 | 7.5、继承
  • Docker部署服务:快速入门指南
  • opencv学习笔记(一)
  • Vue3——Vite篇
  • rmdir :删除空文件夹
  • Stable Diffusion绘画 | XYZ Plot:让对比一目了然
  • 优青博导团队指导-组蛋白甲基化修饰、实验设计、实验结果分析、测序分析及SCI论文辅助,精准高效,为农医学科研保驾护航!
  • 前端——阿里图标的使用
  • USB 电缆中的信号线 DP、DM 的缩写由来
  • 8086的指令系统
  • 物联网实践教程:微信小程序结合OneNET平台MQTT实现STM32单片机远程智能控制 远程上报和接收数据——汇总
  • ESXI主机加入VCENTER现有集群提示出现常规性错误