Make string.index() use a linear KMP search
parent
fc7ac25a98
commit
d1a1f74d33
|
@ -349,23 +349,36 @@ pub fn (s string) substr(start, end int) string {
|
||||||
return res
|
return res
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// KMP search
|
||||||
pub fn (s string) index(p string) int {
|
pub fn (s string) index(p string) int {
|
||||||
if p.len > s.len {
|
if p.len > s.len {
|
||||||
return -1
|
return -1
|
||||||
}
|
}
|
||||||
mut i := 0
|
mut prefix := [0]
|
||||||
for i < s.len {
|
mut j := 0
|
||||||
mut j := 0
|
for i := 1; i < p.len; i++ {
|
||||||
mut ii := i
|
for p[j] != p[i] && j > 0 {
|
||||||
for j < p.len && s[ii] == p[j] {
|
j = prefix[j - 1]
|
||||||
|
}
|
||||||
|
if p[j] == p[i] {
|
||||||
|
j++
|
||||||
|
}
|
||||||
|
prefix << j
|
||||||
|
}
|
||||||
|
j = 0
|
||||||
|
for i := 0; i < s.len; i++ {
|
||||||
|
for p[j] != s[i] && j > 0 {
|
||||||
|
j = prefix[j - 1]
|
||||||
|
}
|
||||||
|
if p[j] == s[i] {
|
||||||
j++
|
j++
|
||||||
ii++
|
|
||||||
}
|
}
|
||||||
if j == p.len {
|
if j == p.len {
|
||||||
return i
|
prefix.free()
|
||||||
|
return i - p.len + 1
|
||||||
}
|
}
|
||||||
i++
|
|
||||||
}
|
}
|
||||||
|
prefix.free()
|
||||||
return -1
|
return -1
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue