zmc
2023-08-08 e792e9a60d958b93aef96050644f369feb25d61b
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
from __future__ import absolute_import, division, unicode_literals
 
try:
    from collections.abc import Mapping
except ImportError:  # Python 2.7
    from collections import Mapping
 
 
class Trie(Mapping):
    """Abstract base class for tries"""
 
    def keys(self, prefix=None):
        # pylint:disable=arguments-differ
        keys = super(Trie, self).keys()
 
        if prefix is None:
            return set(keys)
 
        return {x for x in keys if x.startswith(prefix)}
 
    def has_keys_with_prefix(self, prefix):
        for key in self.keys():
            if key.startswith(prefix):
                return True
 
        return False
 
    def longest_prefix(self, prefix):
        if prefix in self:
            return prefix
 
        for i in range(1, len(prefix) + 1):
            if prefix[:-i] in self:
                return prefix[:-i]
 
        raise KeyError(prefix)
 
    def longest_prefix_item(self, prefix):
        lprefix = self.longest_prefix(prefix)
        return (lprefix, self[lprefix])