Class HashMapLinearProbing<Key,Value>
- java.lang.Object
-
- org.processmining.earthmoversstochasticconformancechecking.datastructures.HashMapLinearProbing<Key,Value>
-
- All Implemented Interfaces:
java.util.Map<Key,Value>
public class HashMapLinearProbing<Key,Value> extends java.lang.Object implements java.util.Map<Key,Value>TheHashMapLinearProbingclass represents a symbol table of generic key-value pairs. It supports the usual put, get, contains, delete, size, and is-empty methods. It also provides a keys method for iterating over all of the keys. A symbol table implements the associative array abstraction: when associating a value with a key that is already in the symbol table, the convention is to replace the old value with the new value. UnlikeMap, this class uses the convention that values cannot benull-setting the value associated with a key tonullis equivalent to deleting the key from the symbol table.This implementation uses a linear probing hash table. It requires that the key type overrides the
equals()andhashCode()methods. The expected time per put, contains, or remove operation is constant, subject to the uniform hashing assumption. The size, and is-empty operations take constant time. Construction takes constant time.For additional documentation, see Section 3.4 of Algorithms, 4th Edition by Robert Sedgewick and Kevin Wayne. For other implementations, see
ST,BinarySearchST,SequentialSearchST,BST,RedBlackBST, andSeparateChainingHashST,- Author:
- brockhoff, Robert Sedgewick, Kevin Wayne
- See Also:
- https://algs4.cs.princeton.edu/34hash/LinearProbingHashST.java.html
-
-
Constructor Summary
Constructors Constructor Description HashMapLinearProbing()Initializes an empty symbol table.HashMapLinearProbing(int capacity)Initializes an empty symbol table with the specified initial capacity.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description voidclear()booleancontainsKey(java.lang.Object key)Returns true if this symbol table contains the specified key.booleancontainsValue(java.lang.Object value)java.util.Set<java.util.Map.Entry<Key,Value>>entrySet()Valueget(java.lang.Object key)Returns the value associated with the specified key.booleanisEmpty()Returns true if this symbol table is empty.java.lang.Iterable<Key>keys()Returns all keys in this symbol table as anIterable.java.util.Set<Key>keySet()Valueput(Key key, Value val)Inserts the specified key-value pair into the symbol table, overwriting the old value with the new value if the symbol table already contains the specified key.voidputAll(java.util.Map<? extends Key,? extends Value> m)Valueremove(java.lang.Object key)Removes the specified key and its associated value from this symbol table (if the key is in this symbol table).intsize()Returns the number of key-value pairs in this symbol table.java.util.Collection<Value>values()
-
-
-
Method Detail
-
size
public int size()
Returns the number of key-value pairs in this symbol table.
-
isEmpty
public boolean isEmpty()
Returns true if this symbol table is empty.
-
containsKey
public boolean containsKey(java.lang.Object key)
Returns true if this symbol table contains the specified key.
-
put
public Value put(Key key, Value val)
Inserts the specified key-value pair into the symbol table, overwriting the old value with the new value if the symbol table already contains the specified key. Deletes the specified key (and its associated value) from this symbol table if the specified value isnull.
-
get
public Value get(java.lang.Object key)
Returns the value associated with the specified key.
-
remove
public Value remove(java.lang.Object key)
Removes the specified key and its associated value from this symbol table (if the key is in this symbol table).
-
keys
public java.lang.Iterable<Key> keys()
Returns all keys in this symbol table as anIterable. To iterate over all of the keys in the symbol table namedst, use the foreach notation:for (Key key : st.keys()).- Returns:
- all keys in this symbol table
-
containsValue
public boolean containsValue(java.lang.Object value)
-
keySet
public java.util.Set<Key> keySet()
-
values
public java.util.Collection<Value> values()
-
-