假设我们必须创建trie结构,使用三种基本操作,如insert()、search()、startsWith()方法。我们可以假设所有输入都是小写字母。例如,如果我们按如下方式调用函数,我们将看到输出
Trie trie = new Trie()
trie.insert("apple")
trie.search("apple") // return true
trie.search("app") //return false
trie.startsWith("app") //return true
trie.insert("app")
trie.search("app") // return true
为了解决这个问题,我们将遵循以下步骤-
让我们看下面的实现以更好地理解-
class Trie(object):
def __init__(self):
self.child = {}
def insert(self, word):
current = self.child
for l in word:
if l not in current:
current[l] = {}
current = current[l]
current['#']=1
def search(self, word):
current = self.child
for l in word:
if l not in current:
return False
current = current[l]
return '#' in current
def startsWith(self, prefix):
current = self.child
for l in prefix:
if l not in current:
return False
current = current[l]
return True
ob1 = Trie()ob1.insert("apple")
print(ob1.search("apple"))
print(ob1.search("app"))
print(ob1.startsWith("app"))
ob1.insert("app")
print(ob1.search("app"))ob1 = Trie()ob1.insert("apple")
print(ob1.search("apple"))
print(ob1.search("app"))
print(ob1.startsWith("app"))
ob1.insert("app")
print(ob1.search("app"))输出结果
True False True True