Class BST<Key extends Comparable<Key>,Value>
- Object
-
- edu.princeton.cs.algs4.BST<Key,Value>
-
public class BST<Key extends Comparable<Key>,Value> extends Object
TheBST
class represents an ordered symbol table of generic key-value pairs. It supports the usual put, get, contains, delete, size, and is-empty methods. It also provides ordered methods for finding the minimum, maximum, floor, select, ceiling. 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 tonull
is equivalent to deleting the key from the symbol table.It requires that the key type implements the
Comparable
interface and calls thecompareTo()
and method to compare two keys. It does not call eitherequals()
orhashCode()
.This implementation uses an (unbalanced) binary search tree. The put, contains, remove, minimum, maximum, ceiling, floor, select, and rank operations each take Θ(n) time in the worst case, where n is the number of key-value pairs. The size and is-empty operations take Θ(1) time. The keys method takes Θ(n) time in the worst case. Construction takes Θ(1) time.
For alternative implementations of the symbol table API, see
ST
,BinarySearchST
,SequentialSearchST
,RedBlackBST
,SeparateChainingHashST
, andLinearProbingHashST
, For additional documentation, see Section 3.2 of Algorithms, 4th Edition by Robert Sedgewick and Kevin Wayne.- Author:
- Robert Sedgewick, Kevin Wayne
-
-
Constructor Summary
Constructors Constructor Description BST()
Initializes an empty symbol table.
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description Key
ceiling(Key key)
Returns the smallest key in the symbol table greater than or equal tokey
.boolean
contains(Key key)
Does this symbol table contain the given key?void
delete(Key key)
Removes the specified key and its associated value from this symbol table (if the key is in this symbol table).void
deleteMax()
Removes the largest key and associated value from the symbol table.void
deleteMin()
Removes the smallest key and associated value from the symbol table.Key
floor(Key key)
Returns the largest key in the symbol table less than or equal tokey
.Key
floor2(Key key)
Value
get(Key key)
Returns the value associated with the given key.int
height()
Returns the height of the BST (for debugging).boolean
isEmpty()
Returns true if this symbol table is empty.Iterable<Key>
keys()
Returns all keys in the symbol table in ascending order, as anIterable
.Iterable<Key>
keys(Key lo, Key hi)
Returns all keys in the symbol table in the given range in ascending order, as anIterable
.Iterable<Key>
levelOrder()
Returns the keys in the BST in level order (for debugging).static void
main(String[] args)
Unit tests theBST
data type.Key
max()
Returns the largest key in the symbol table.Key
min()
Returns the smallest key in the symbol table.void
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.int
rank(Key key)
Return the number of keys in the symbol table strictly less thankey
.Key
select(int rank)
Return the key in the symbol table of a givenrank
.int
size()
Returns the number of key-value pairs in this symbol table.int
size(Key lo, Key hi)
Returns the number of keys in the symbol table in the given range.
-
-
-
Method Detail
-
isEmpty
public boolean isEmpty()
Returns true if this symbol table is empty.- Returns:
true
if this symbol table is empty;false
otherwise
-
size
public int size()
Returns the number of key-value pairs in this symbol table.- Returns:
- the number of key-value pairs in this symbol table
-
contains
public boolean contains(Key key)
Does this symbol table contain the given key?- Parameters:
key
- the key- Returns:
true
if this symbol table containskey
andfalse
otherwise- Throws:
IllegalArgumentException
- ifkey
isnull
-
get
public Value get(Key key)
Returns the value associated with the given key.- Parameters:
key
- the key- Returns:
- the value associated with the given key if the key is in the symbol table
and
null
if the key is not in the symbol table - Throws:
IllegalArgumentException
- ifkey
isnull
-
put
public void 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
.- Parameters:
key
- the keyval
- the value- Throws:
IllegalArgumentException
- ifkey
isnull
-
deleteMin
public void deleteMin()
Removes the smallest key and associated value from the symbol table.- Throws:
NoSuchElementException
- if the symbol table is empty
-
deleteMax
public void deleteMax()
Removes the largest key and associated value from the symbol table.- Throws:
NoSuchElementException
- if the symbol table is empty
-
delete
public void delete(Key key)
Removes the specified key and its associated value from this symbol table (if the key is in this symbol table).- Parameters:
key
- the key- Throws:
IllegalArgumentException
- ifkey
isnull
-
min
public Key min()
Returns the smallest key in the symbol table.- Returns:
- the smallest key in the symbol table
- Throws:
NoSuchElementException
- if the symbol table is empty
-
max
public Key max()
Returns the largest key in the symbol table.- Returns:
- the largest key in the symbol table
- Throws:
NoSuchElementException
- if the symbol table is empty
-
floor
public Key floor(Key key)
Returns the largest key in the symbol table less than or equal tokey
.- Parameters:
key
- the key- Returns:
- the largest key in the symbol table less than or equal to
key
- Throws:
NoSuchElementException
- if there is no such keyIllegalArgumentException
- ifkey
isnull
-
ceiling
public Key ceiling(Key key)
Returns the smallest key in the symbol table greater than or equal tokey
.- Parameters:
key
- the key- Returns:
- the smallest key in the symbol table greater than or equal to
key
- Throws:
NoSuchElementException
- if there is no such keyIllegalArgumentException
- ifkey
isnull
-
select
public Key select(int rank)
Return the key in the symbol table of a givenrank
. This key has the property that there arerank
keys in the symbol table that are smaller. In other words, this key is the (rank
+1)st smallest key in the symbol table.- Parameters:
rank
- the order statistic- Returns:
- the key in the symbol table of given
rank
- Throws:
IllegalArgumentException
- unlessrank
is between 0 and n–1
-
rank
public int rank(Key key)
Return the number of keys in the symbol table strictly less thankey
.- Parameters:
key
- the key- Returns:
- the number of keys in the symbol table strictly less than
key
- Throws:
IllegalArgumentException
- ifkey
isnull
-
keys
public Iterable<Key> keys()
Returns all keys in the symbol table in ascending order, 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 the symbol table in ascending order
-
keys
public Iterable<Key> keys(Key lo, Key hi)
Returns all keys in the symbol table in the given range in ascending order, as anIterable
.- Parameters:
lo
- minimum endpointhi
- maximum endpoint- Returns:
- all keys in the symbol table between
lo
(inclusive) andhi
(inclusive) in ascending order - Throws:
IllegalArgumentException
- if eitherlo
orhi
isnull
-
size
public int size(Key lo, Key hi)
Returns the number of keys in the symbol table in the given range.- Parameters:
lo
- minimum endpointhi
- maximum endpoint- Returns:
- the number of keys in the symbol table between
lo
(inclusive) andhi
(inclusive) - Throws:
IllegalArgumentException
- if eitherlo
orhi
isnull
-
height
public int height()
Returns the height of the BST (for debugging).- Returns:
- the height of the BST (a 1-node tree has height 0)
-
levelOrder
public Iterable<Key> levelOrder()
Returns the keys in the BST in level order (for debugging).- Returns:
- the keys in the BST in level order traversal
-
main
public static void main(String[] args)
Unit tests theBST
data type.- Parameters:
args
- the command-line arguments
-
-