Total Complexity | 7 |
Total Lines | 27 |
Duplicated Lines | 0 % |
Changes | 1 | ||
Bugs | 0 | Features | 0 |
1 | |||
2 | class LongestRepeatedSubstringSearch(object): |
||
3 | @staticmethod |
||
4 | def lrs(text, pattern): |
||
5 | n = len(text) |
||
6 | a = [''] * n |
||
7 | for i in range(0, n): |
||
8 | a[i] = text[i:] |
||
9 | |||
10 | sorted(a) |
||
11 | |||
12 | max_len = 0 |
||
13 | j = -1 |
||
14 | for i in range(0, n): |
||
15 | l = LongestRepeatedSubstringSearch.lcp(a[i], pattern) |
||
16 | if l > max_len: |
||
17 | j = i |
||
18 | max_len = l |
||
19 | |||
20 | return (j, max_len) |
||
21 | |||
22 | @staticmethod |
||
23 | def lcp(text, pattern): |
||
24 | i = 0 |
||
25 | for i in range(min(len(text), len(pattern))): |
||
26 | if text[i] != pattern[i]: |
||
27 | return i |
||
28 | return i |
||
29 |