类 ST<Key extends java.lang.Comparable<Key>,Value>
- java.lang.Object
-
- edu.princeton.cs.algs4.ST<Key,Value>
-
- 类型参数:
Key- the generic type of keys in this symbol tableValue- the generic type of values in this symbol table
- 所有已实现的接口:
java.lang.Iterable<Key>
public class ST<Key extends java.lang.Comparable<Key>,Value> extends java.lang.Object implements java.lang.Iterable<Key>TheSTclass 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, and 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 tonullis equivalent to deleting the key from the symbol table.This implementation uses a balanced binary search tree. It requires that the key type implements the
Comparableinterface and calls thecompareTo()and method to compare two keys. It does not call eitherequals()orhashCode(). The put, contains, remove, minimum, maximum, ceiling, and floor operations each take logarithmic time in the worst case. The size, and is-empty operations take constant time. Construction takes constant time.For additional documentation, see Section 3.5 of Algorithms, 4th Edition by Robert Sedgewick and Kevin Wayne.
-
-
构造器概要
构造器 构造器 说明 ST()Initializes an empty symbol table.
-
方法概要
修饰符和类型 方法 说明 Keyceiling(Key key)Returns the smallest key in this symbol table greater than or equal tokey.booleancontains(Key key)Returns true if this symbol table contain the given key.voiddelete(Key key)Removes the specified key and its associated value from this symbol table (if the key is in this symbol table).Keyfloor(Key key)Returns the largest key in this symbol table less than or equal tokey.Valueget(Key key)Returns the value associated with the given key in this symbol table.booleanisEmpty()Returns true if this symbol table is empty.java.util.Iterator<Key>iterator()已过时。Replaced bykeys().java.lang.Iterable<Key>keys()Returns all keys in this symbol table.static voidmain(java.lang.String[] args)Unit tests theSTdata type.Keymax()Returns the largest key in this symbol table.Keymin()Returns the smallest key in this symbol table.voidput(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.intsize()Returns the number of key-value pairs in this symbol table.
-
-
-
方法详细资料
-
get
public Value get(Key key)
Returns the value associated with the given key in this symbol table.- 参数:
key- the key- 返回:
- the value associated with the given key if the key is in this symbol table;
nullif the key is not in this symbol table - 抛出:
java.lang.IllegalArgumentException- ifkeyisnull
-
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.- 参数:
key- the keyval- the value- 抛出:
java.lang.IllegalArgumentException- ifkeyisnull
-
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).- 参数:
key- the key- 抛出:
java.lang.IllegalArgumentException- ifkeyisnull
-
contains
public boolean contains(Key key)
Returns true if this symbol table contain the given key.- 参数:
key- the key- 返回:
trueif this symbol table containskeyandfalseotherwise- 抛出:
java.lang.IllegalArgumentException- ifkeyisnull
-
size
public int size()
Returns the number of key-value pairs in this symbol table.- 返回:
- the number of key-value pairs in this symbol table
-
isEmpty
public boolean isEmpty()
Returns true if this symbol table is empty.- 返回:
trueif this symbol table is empty andfalseotherwise
-
keys
public java.lang.Iterable<Key> keys()
Returns all keys in this symbol table.To iterate over all of the keys in the symbol table named
st, use the foreach notation:for (Key key : st.keys()).- 返回:
- all keys in this symbol table
-
iterator
@Deprecated public java.util.Iterator<Key> iterator()
已过时。Replaced bykeys().Returns all of the keys in this symbol table. To iterate over all of the keys in a symbol table namedst, use the foreach notation:for (Key key : st).This method is provided for backward compatibility with the version from Introduction to Programming in Java: An Interdisciplinary Approach.
-
min
public Key min()
Returns the smallest key in this symbol table.- 返回:
- the smallest key in this symbol table
- 抛出:
java.util.NoSuchElementException- if this symbol table is empty
-
max
public Key max()
Returns the largest key in this symbol table.- 返回:
- the largest key in this symbol table
- 抛出:
java.util.NoSuchElementException- if this symbol table is empty
-
ceiling
public Key ceiling(Key key)
Returns the smallest key in this symbol table greater than or equal tokey.- 参数:
key- the key- 返回:
- the smallest key in this symbol table greater than or equal to
key - 抛出:
java.util.NoSuchElementException- if there is no such keyjava.lang.IllegalArgumentException- ifkeyisnull
-
floor
public Key floor(Key key)
Returns the largest key in this symbol table less than or equal tokey.- 参数:
key- the key- 返回:
- the largest key in this symbol table less than or equal to
key - 抛出:
java.util.NoSuchElementException- if there is no such keyjava.lang.IllegalArgumentException- ifkeyisnull
-
main
public static void main(java.lang.String[] args)
Unit tests theSTdata type.- 参数:
args- the command-line arguments
-
-