• JAVA:实现RabinKarpAlgorithm拉宾卡普算法(附完整源码)


    JAVA:实现RabinKarpAlgorithm拉宾卡普算法

    package com.thealgorithms.searches;
    
    public class RabinKarpAlgorithm
    {
        // d is the number of characters in the input alphabet
        public final static int d = 256;
          
        /* pat -> pattern
            txt -> text
            q -> A prime number
        */
        public int search(String pat, String txt, int q)
        {
        	int index = -1; //note: -1 here represent not found, it is not an index
            int M = pat.length();
            int N = txt.length();
            int i, j;
            int p = 0; // hash value for pattern
            int t = 0; // hash value for txt
            int h = 1;
          
            // The value of h would be "pow(d, M-1)%q"
            for (i = 0; i < M-1; i++)
                h = (h*d)%q;
          
            // Calculate the hash value of pattern and first
            // window of text
            for (i = 0; i < M; i++)
            {
                p = (d*p + pat.charAt(i))%q;
                t = (d*t + txt.charAt(i))%q;
            }
          
            // Slide the pattern over text one by one
            for (i = 0; i <= N - M; i++)
            {
          
                // Check the hash values of current window of text
                // and pattern. If the hash values match then only
                // check for characters one by one
                if ( p == t )
                {
                    /* Check for characters one by one */
                    for (j = 0; j < M; j++)
                    {
                        if (txt.charAt(i+j) != pat.charAt(j))
                            break;
                    }
          
                    // if p == t and pat[0...M-1] = txt[i, i+1, ...i+M-1]
                    if (j == M) {
                        System.out.println("Pattern found at index " + i);
                        index= i;
                        return index ;
                    }
                }
          
                // Calculate hash value for next window of text: Remove
                // leading digit, add trailing digit
                if ( i < N-M )
                {
                    t = (d*(t - txt.charAt(i)*h) + txt.charAt(i+M))%q;
          
                    // We might get negative value of t, converting it
                    // to positive
                    if (t < 0)
                    t = (t + q);
                }
            }
            return index; // return -1 if pattern does not found
        }
          
    }
      
    // This code is contributed by nuclode
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
    • 60
    • 61
    • 62
    • 63
    • 64
    • 65
    • 66
    • 67
    • 68
    • 69
    • 70
    • 71
    • 72
    • 73
    • 74
    • 75
    • 76
  • 相关阅读:
    报错:Unknown at rule @apply
    RocketMQ(三):集成SpringBoot
    ISIS双栈原理
    使用 dynamic-datasource 完成多数据源操作
    数据库入门(SQL SEVER)之SQL语句删除单行数据,所有行数据,表和数据库
    JAVA小游戏 “拼图”
    Hadoop架构、组件、及其术语汇总和理解
    chap4Web服务器-入门学习笔记
    Cplex混合整数规划求解(Python API)
    基于鲸鱼算法优化的lssvm回归预测-附代码
  • 原文地址:https://blog.csdn.net/it_xiangqiang/article/details/126315477