-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathindex.py
More file actions
41 lines (33 loc) · 1.01 KB
/
index.py
File metadata and controls
41 lines (33 loc) · 1.01 KB
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
class Node(dict):
def __init__(self, prefix=""):
self.prefix = prefix
self.final = False
def find(self, s):
return self.find_helper(s, 0)
def find_helper(self, s, n):
if n < len(s):
if not s[n] in self:
return None
else:
return self[s[n]].find_helper(s, n+1)
else:
return self
def insert(self, s):
self.insert_helper(s, 0)
def insert_helper(self, s, n):
if n < len(s):
branch = self.get( s[n], Node(prefix=self.prefix+s[n]) )
branch.insert_helper(s, n+1)
self[s[n]] = branch
else:
self.final=True
def contains(self, s):
return self.contains_helper(s, 0)
def contains_helper(self, s, n):
if n < len(s):
if not s[n] in self:
return False
else:
return self[s[n]].contains_helper(s, n+1)
else:
return self.final