acwing 841 字符串哈希

简介: acwing 841 字符串哈希

活动 - AcWing

字符串哈希,对每一个样式的字符串找一个他的映射值,如果两个字符串的映射值相同,就说明这两个字符串相同。

刚学的刚学的,写的不好刚学的

#include<iostream>
#include<cstring>
#include<algorithm>
 
using namespace std ;
typedef unsigned long long ULL ;
const int N = 1e5 +10, P = 131  ;
char a[N];
ULL h[N] , p[N] ;
ULL get(int l ,int  r) {
  return h[r] - h[l-1] * p[r-l+1] ; 
}
int main(){
  int n , m ;
  cin >> n >> m ;
  scanf("%s",a+1) ;
  p[0] = 1 ;
  for(int i = 1 ; i <= n ; i++){
    h[i] = h[i-1]*P + a[i] ;
    p[i] = p[i-1] * P ;
  }
  while(m --){
    int x1 , y1 , x2, y2 ;
    cin >> x1 >> y1 >> x2 >> y2 ;
    if(get(x1,y1) == get(x2,y2)) {
      cout << "Yes" << endl ;
    }else cout << "No" << endl ;
  }
}
目录
相关文章
|
3月前
AcWing 831. KMP字符串
AcWing 831. KMP字符串
18 0
|
7月前
|
算法
力扣每日一题 6/16 字符串 + 随机一题 动态规划/数学
力扣每日一题 6/16 字符串 + 随机一题 动态规划/数学
54 0
|
8月前
|
机器学习/深度学习 人工智能 测试技术
【动态规划】【矩阵快速幂】LeetCode2851. 字符串转换
【动态规划】【矩阵快速幂】LeetCode2851. 字符串转换
|
8月前
|
算法 C#
Leetcode算法系列| 5. 最长回文子串
Leetcode算法系列| 5. 最长回文子串
|
算法 vr&ar C++
【AcWing】双指针算法
这一篇博客也用了双指针算法,同学们可以参考一下
110 0
|
算法
算法:next数组的求法详解
算法:next数组的求法详解
877 0
算法:next数组的求法详解
|
机器学习/深度学习 算法
【递归与递推 4】AcWing95. 费解的开关 、AcWing 93. 递归实现组合型枚举、AcWing 1209. 带分数、AcWing 1208. 翻硬币
【递归与递推 4】AcWing95. 费解的开关 、AcWing 93. 递归实现组合型枚举、AcWing 1209. 带分数、AcWing 1208. 翻硬币
167 0
|
算法
每日一题之字符串哈希
大家好,我是泡泡,给大家带来每日一题的目的是为了更好的练习算法,我们的每日一题这个月进度是数据结构,让大家练到各种各样的数据结构题目,熟悉数据结构的增删改查,一年以后,蜕变成为一个不一样的自己!
151 0
每日一题之字符串哈希

热门文章

最新文章

下一篇
开通oss服务