Class PatriciaTrie<E>
- java.lang.Object
-
- java.util.AbstractMap<K,V>
-
- org.apache.commons.collections4.trie.AbstractBitwiseTrie<K,V>
-
- org.apache.commons.collections4.trie.PatriciaTrie<E>
-
- Type Parameters:
E- the type of the values in this map
- All Implemented Interfaces:
Serializable,Map<String,E>,SortedMap<String,E>,Get<String,E>,IterableGet<String,E>,IterableMap<String,E>,IterableSortedMap<String,E>,OrderedMap<String,E>,Put<String,E>,Trie<String,E>
public class PatriciaTrie<E> extends AbstractBitwiseTrie<K,V>
Implementation of a PATRICIA Trie (Practical Algorithm to Retrieve Information Coded in Alphanumeric).A PATRICIA
Trieis a compressedTrie. Instead of storing all data at the edges of theTrie(and having empty internal nodes), PATRICIA stores data in every node. This allows for very efficient traversal, insert, delete, predecessor, successor, prefix, range, andselect(Object)operations. All operations are performed at worst in O(K) time, where K is the number of bits in the largest item in the tree. In practice, operations actually take O(A(K)) time, where A(K) is the average number of bits of all items in the tree.Most importantly, PATRICIA requires very few comparisons to keys while doing any operation. While performing a lookup, each comparison (at most K of them, described above) will perform a single bit comparison against the given key, instead of comparing the entire key to another key.
The
Triecan return operations in lexicographical order using the 'prefixMap', 'submap', or 'iterator' methods. TheTriecan also scan for items that are 'bitwise' (using an XOR metric) by the 'select' method. Bitwise closeness is determined by theKeyAnalyzerreturning true or false for a bit being set or not in a given key.This PATRICIA
Triesupports both variable length & fixed length keys. Some methods, such asTrie.prefixMap(Object)are suited only to variable length keys.- Since:
- 4.0
- See Also:
- Radix Tree, PATRICIA, Crit-Bit Tree, Serialized Form
-
-
Nested Class Summary
-
Nested classes/interfaces inherited from class java.util.AbstractMap
AbstractMap.SimpleEntry<K extends Object,V extends Object>, AbstractMap.SimpleImmutableEntry<K extends Object,V extends Object>
-
-
Constructor Summary
Constructors Constructor Description PatriciaTrie()PatriciaTrie(Map<? extends String,? extends E> m)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description voidclear()Comparator<? super K>comparator()booleancontainsKey(Object k)Set<Map.Entry<K,V>>entrySet()KfirstKey()Gets the first key currently in this map.Vget(Object k)SortedMap<K,V>headMap(K toKey)Set<K>keySet()KlastKey()Gets the last key currently in this map.OrderedMapIterator<K,V>mapIterator()Obtains anOrderedMapIteratorover the map.KnextKey(K key)Gets the next key after the one specified.SortedMap<K,V>prefixMap(K key)Returns a view of thisTrieof all elements that are prefixed by the given key.KpreviousKey(K key)Gets the previous key before the one specified.Vput(K key, V value)Note that the return type is Object, rather than V as in the Map interface.Vremove(Object k)Map.Entry<K,V>select(K key)Returns theMap.Entrywhose key is closest in a bitwise XOR metric to the given key.KselectKey(K key)Returns the key that is closest in a bitwise XOR metric to the provided key.VselectValue(K key)Returns the value whose key is closest in a bitwise XOR metric to the provided key.intsize()SortedMap<K,V>subMap(K fromKey, K toKey)SortedMap<K,V>tailMap(K fromKey)Collection<V>values()-
Methods inherited from class org.apache.commons.collections4.trie.AbstractBitwiseTrie
toString
-
Methods inherited from class java.util.AbstractMap
containsValue, equals, hashCode, isEmpty, putAll
-
Methods inherited from interface org.apache.commons.collections4.Get
containsValue, isEmpty
-
Methods inherited from interface java.util.Map
compute, computeIfAbsent, computeIfPresent, containsValue, equals, forEach, getOrDefault, hashCode, isEmpty, merge, putAll, putIfAbsent, remove, replace, replace, replaceAll
-
-
-
-
Method Detail
-
clear
public void clear()
- Specified by:
clearin interfaceMap<K,V>- Specified by:
clearin interfacePut<K,V>- Overrides:
clearin classAbstractMap<K,V>- See Also:
Map.clear()
-
size
public int size()
- Specified by:
sizein interfaceGet<K,V>- Specified by:
sizein interfaceMap<K,V>- Overrides:
sizein classAbstractMap<K,V>- Returns:
- the number of key-value mappings in this map
- See Also:
Map.size()
-
put
public V put(K key, V value)Description copied from interface:PutNote that the return type is Object, rather than V as in the Map interface. See the class Javadoc for further info.- Specified by:
putin interfaceMap<K,V>- Specified by:
putin interfacePut<K,V>- Overrides:
putin classAbstractMap<K,V>- Parameters:
key- key with which the specified value is to be associatedvalue- value to be associated with the specified key- Returns:
- the previous value associated with
key, ornullif there was no mapping forkey. (Anullreturn can also indicate that the map previously associatednullwithkey, if the implementation supportsnullvalues.) - See Also:
Map.put(Object, Object)
-
get
public V get(Object k)
- Specified by:
getin interfaceGet<K,V>- Specified by:
getin interfaceMap<K,V>- Overrides:
getin classAbstractMap<K,V>- Parameters:
k- the key whose associated value is to be returned- Returns:
- the value to which the specified key is mapped, or
nullif this map contains no mapping for the key - See Also:
Map.get(Object)
-
select
public Map.Entry<K,V> select(K key)
Returns theMap.Entrywhose key is closest in a bitwise XOR metric to the given key. This is NOT lexicographic closeness. For example, given the keys:- D = 1000100
- H = 1001000
- L = 1001100
Triecontained 'H' and 'L', a lookup of 'D' would return 'L', because the XOR distance between D & L is smaller than the XOR distance between D & H.- Parameters:
key- the key to use in the search- Returns:
- the
Map.Entrywhose key is closest in a bitwise XOR metric to the provided key
-
selectKey
public K selectKey(K key)
Returns the key that is closest in a bitwise XOR metric to the provided key. This is NOT lexicographic closeness! For example, given the keys:- D = 1000100
- H = 1001000
- L = 1001100
Triecontained 'H' and 'L', a lookup of 'D' would return 'L', because the XOR distance between D & L is smaller than the XOR distance between D & H.- Parameters:
key- the key to use in the search- Returns:
- the key that is closest in a bitwise XOR metric to the provided key
-
selectValue
public V selectValue(K key)
Returns the value whose key is closest in a bitwise XOR metric to the provided key. This is NOT lexicographic closeness! For example, given the keys:- D = 1000100
- H = 1001000
- L = 1001100
Triecontained 'H' and 'L', a lookup of 'D' would return 'L', because the XOR distance between D & L is smaller than the XOR distance between D & H.- Parameters:
key- the key to use in the search- Returns:
- the value whose key is closest in a bitwise XOR metric to the provided key
-
containsKey
public boolean containsKey(Object k)
- Specified by:
containsKeyin interfaceGet<K,V>- Specified by:
containsKeyin interfaceMap<K,V>- Overrides:
containsKeyin classAbstractMap<K,V>- Parameters:
k- key whose presence in this map is to be tested- Returns:
trueif this map contains a mapping for the specified key- See Also:
Map.containsKey(Object)
-
entrySet
public Set<Map.Entry<K,V>> entrySet()
- Specified by:
entrySetin interfaceGet<K,V>- Specified by:
entrySetin interfaceMap<K,V>- Specified by:
entrySetin interfaceSortedMap<K,V>- Specified by:
entrySetin classAbstractMap<K,V>- Returns:
- a set view of the mappings contained in this map
- See Also:
Map.entrySet()
-
keySet
public Set<K> keySet()
- Specified by:
keySetin interfaceGet<K,V>- Specified by:
keySetin interfaceMap<K,V>- Specified by:
keySetin interfaceSortedMap<K,V>- Overrides:
keySetin classAbstractMap<K,V>- Returns:
- a set view of the keys contained in this map
- See Also:
Map.keySet()
-
values
public Collection<V> values()
- Specified by:
valuesin interfaceGet<K,V>- Specified by:
valuesin interfaceMap<K,V>- Specified by:
valuesin interfaceSortedMap<K,V>- Overrides:
valuesin classAbstractMap<K,V>- Returns:
- a collection view of the values contained in this map
- See Also:
Map.values()
-
remove
public V remove(Object k)
- Specified by:
removein interfaceGet<K,V>- Specified by:
removein interfaceMap<K,V>- Overrides:
removein classAbstractMap<K,V>- Parameters:
k- key whose mapping is to be removed from the map- Returns:
- the previous value associated with
key, ornullif there was no mapping forkey. - Throws:
ClassCastException- if provided key is of an incompatible type- See Also:
Map.remove(Object)
-
comparator
public Comparator<? super K> comparator()
-
firstKey
public K firstKey()
Description copied from interface:OrderedMapGets the first key currently in this map.- Returns:
- the first key currently in this map
-
lastKey
public K lastKey()
Description copied from interface:OrderedMapGets the last key currently in this map.- Returns:
- the last key currently in this map
-
nextKey
public K nextKey(K key)
Description copied from interface:OrderedMapGets the next key after the one specified.- Parameters:
key- the key to search for next from- Returns:
- the next key, null if no match or at end
-
previousKey
public K previousKey(K key)
Description copied from interface:OrderedMapGets the previous key before the one specified.- Parameters:
key- the key to search for previous from- Returns:
- the previous key, null if no match or at start
-
mapIterator
public OrderedMapIterator<K,V> mapIterator()
Description copied from interface:OrderedMapObtains anOrderedMapIteratorover the map.A ordered map iterator is an efficient way of iterating over maps in both directions.
- Returns:
- a map iterator
-
prefixMap
public SortedMap<K,V> prefixMap(K key)
Description copied from interface:TrieReturns a view of thisTrieof all elements that are prefixed by the given key.In a
Triewith fixed size keys, this is essentially aMap.get(Object)operation.For example, if the
Triecontains 'Anna', 'Anael', 'Analu', 'Andreas', 'Andrea', 'Andres', and 'Anatole', then a lookup of 'And' would return 'Andreas', 'Andrea', and 'Andres'.
-
headMap
public SortedMap<K,V> headMap(K toKey)
-
subMap
public SortedMap<K,V> subMap(K fromKey, K toKey)
-
tailMap
public SortedMap<K,V> tailMap(K fromKey)
-
-