字符串哈希模板(Java实现)

字符串哈希的本质就是一个用数字表示一段字符串,从而降低字符串处理的复杂度,这个数字我们一般用long类型,同时需要一个进制数base,用于规定这个数字的进制,Hash数组h[i]表示字符串s[1~i]的Hash值,采用类似前缀和的形式求出任意一个子串的哈希值,具体的原理大致就是这样,我也不细说了,我主要写模板。

 

import java.math.BigInteger;
import java.util.*;

public class Main {

    public static void main(String[] args) {
        Scanner scanner=new Scanner(System.in);
        //输入的字符串都是大写字母
        char[] c1=scanner.next().toCharArray();
        char[] c2=scanner.next().toCharArray();
        //表示的是c1在c2中出现的次数
        int n=c1.length;
        int m=c2.length;
        long[] h=new long[m+1];//h[i]表示第i处的哈希值
        long[] b=new long[m+1];//表示的以base为底的i次方
        long base=131;
        long res=0;//c1的哈希值
        //计算c1的哈希值
        for(int i=0;i<n;i++){
            res=res*base+(c1[i]-'A'+1);
        }
        b[0]=1;
        //计算c2的字母哈希值
        for(int i=1;i<=m;i++){
            h[i]=h[i-1]*base+c2[i-1]-'A'+1;
            b[i]=b[i-1]*base;
        }
        int ans=0;//记录c1在c2中出现的次数
        for(int i=1;i+n-1<=m;i++){
            long sum=h[i+n-1]-h[i-1]*b[n];
            if(sum==res)ans++;
        }
        System.out.println(ans);
    }

}

题目链接:斤斤计较的小z(样例二是错的)

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

菜到极致就是渣

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值