-
Notifications
You must be signed in to change notification settings - Fork 150
/
Copy pathKMP.kt
38 lines (35 loc) · 1.05 KB
/
KMP.kt
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
package io.uuddlrlrba.ktalgs.substring
class KMP(val pat: String) {
private val R: Int = 256 // the radix
private val dfa: Array<IntArray> // the KMP automoton
init {
// build DFA from pattern
val m = pat.length
dfa = Array(R) { IntArray(m) }
dfa[pat[0].toInt()][0] = 1
var x = 0
var j = 1
while (j < m) {
for (c in 0 until R) {
dfa[c][j] = dfa[c][x] // Copy mismatch cases.
}
dfa[pat[j].toInt()][j] = j + 1 // Set match case.
x = dfa[pat[j].toInt()][x] // Update restart state.
j++
}
}
fun search(txt: String): Int {
// simulate operation of DFA on text
val m = pat.length
val n = txt.length
var i: Int = 0
var j: Int
j = 0
while (i < n && j < m) {
j = dfa[txt[i].toInt()][j]
i++
}
if (j == m) return i - m // found
return n // not found
}
}