-
Notifications
You must be signed in to change notification settings - Fork 0
/
KMP.cpp
66 lines (55 loc) · 1.11 KB
/
KMP.cpp
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
// KMP ALGORITHM
// Frequency Of Substring In A String
#include <iostream>
using namespace std;
void compareLPS(string sub, int m, int lps[]){
lps[0] = 0;
int i = 1, len = 0;
while(i < m){
if(sub[i] == sub[len]){
len++;
lps[i] = len;
i++;
}
else{
if(len != 0){
len = lps[len - 1];
}
else{
lps[i] = len;
i++;
}
}
}
}
int main() {
string parent = "timtimtim";
string sub = "timtimt";
int n = parent.size();
int m = sub.size();
int lps[m];
compareLPS(sub, m, lps);
int j = 0;
int i = 0;
int res = 0;
while(i < n){
if(sub[j] == parent[i]){
j++;
i++;
}
if(j == m){
j = lps[j-1];
res++;
}
else if(i < n && sub[j] != parent[i]){
if(j != 0){
j = lps[j-1];
}
else{
i+=1;
}
}
}
cout << res;
return 0;
}