1 / 18

Lecture 9 Maps

Lecture 9 Maps. The Map interface Example Views More example Hash tables. Map. The Map Interface. A Map is an object that maps keys to values (think of this as an array where the indices are objects). A map cannot contain duplicate keys: Each key can map to at most one value.

jerry
Télécharger la présentation

Lecture 9 Maps

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Lecture 9Maps • The Map interface • Example • Views • More example • Hash tables

  2. Map The Map Interface • A Map is an object that maps keys to values (think of this as an array where the indices are objects). • A map cannot contain duplicate keys: • Each key can map to at most one value. • The Map interface follows on next slide • Does NOT inherit from Collection 9-2

  3. public interface Map <K,V> { //Basic operations V put(K key, V value); V get(Object key); V remove(Object key); boolean containsKey(Object key); boolean containsValue(Object value); int size(); boolean isEmpty(); //Bulk operations void putAll(Map<? extends K,? extends V> t); void clear(); Note K, V and ? stand for generic classes 9-3

  4. // Collection Views public Set<K> keySet(); public Collection<V> values(); public Set<Map.Entry<K,V>> entrySet(); // Interface for entrySet elements public interface Entry { K getKey(); V getValue(); V setValue(V value); } } 9-4

  5. NOTE ‘for loop’, shorthand for; for (inti=0; i<args.length; i++) { String a=args[i]; ... } GOOD IDEA OR NOT? Example import java.util.*; public class Freq { public static void main(String args[]) { Map<String, Integer> m = new HashMap<String, Integer>(); // Initialize frequency table from command line for (String a : args) { Integer freq = m.get(a); m.put(a, (freq == null ? 1 : freq + 1)); } System.out.println(m.size() + " distinct words:"); System.out.println(m); } } 9-5

  6. Map Collection Views • The Collection view methods allow a Map to be viewed as a Collection in these three ways: • keySet () • the Set of keys contained in the Map. • values () • The Collection of values contained in the Map. This Collection is not a Set, because multiple keys can map to the same value. • entrySet() • the Set of key-value pairs contained in the Map. The Map interface provides a small nested interface called Map.Entry, the type of the elements in this Set. • The Collection views provide the only means to iterate over a Map 9-6

  7. Example code for (KeyType key : m.keySet()) System.out.println(key); //Filter a map based on some property of its keys. for (Iterator<Type> i=m.keySet().iterator(); i.hasNext(); ) if (i.next().isBogus()) i.remove(); 9-7

  8. MapExample public class Freq { public static void main(String[] args) { Map<String, Integer> m = new HashMap<String, Integer>(); // Initialize frequency table from command line for (String a : args) { Integer freq = m.get(a); m.put(a, (freq == null) ? 1 : freq + 1); } System.out.println(m.size() + " distinct words:"); System.out.println(m); } } 9-8

  9. MapExample public class Freq { public static void main(String[] args) { Map<String, Integer> m = new TreeMap<String, Integer>(); // Initialize frequency table from command line for (String a : args) { Integer freq = m.get(a); m.put(a, (freq == null) ? 1 : freq + 1); } System.out.println(m.size() + " distinct words:"); System.out.println(m); } } 9-9

  10. Output from examples HashMap unsorted TreeMap sorted 9-10

  11. Hash Tables • HashSets and HashMaps are implemented using a data structure known as a hash table. • You don't need to understand hash tables to use HashSets or HashMaps, but any computer programmer should be familiar with hash tables and how they work. • Hash tables are an elegant solution to the search problem. • A hash table, like a HashMap, stores key/value pairs. Given a key, you have to search the table for the corresponding key/value pair. • When a hash table is used to implement a set, the values are all null, and the only question is whether or not the key occurs in the set.

  12. Hash Tables (2) • You still have to search for the key to check whether it is there or not. • In most search algorithms, in order to find the item you are interested in, you have to look at other items that don't interest you. • To find something in an unsorted list, you have to go though the items one-by-one until you come to the one you are looking for. • In a binary sort tree, you have to start at the root and move down the tree until you find the item you want. • When you search for a key/value pair in a hash table, you can go directly to the location that contains the item you want.

  13. Hash Tables (3) • You don't have to look at any other items. (This is not quite true, but it's close.) • The location of the key/value pair is computed from the key: • You just look at the key, and then you go directly to the location where it is stored. • How can this work? If the keys were integers in the range 0 to 99, we could store the key/value pairs in an array, A, of 100 elements. • The key/value pair with key N would be stored in A[N]. • The key takes us directly to the location of the key/value pair.

  14. Hash Tables (4) • The problem is that there are usually far too many different possible keys for us to be able to use an array with one location for each possible key. • For example, if the key can be any value of type int, then we would need an array with over four billion locations -- quite a waste of space if we are only going to store, say, a few thousand items! • If the key can be a string of any length, then the number of possible keys is infinite, and using an array with one location for each possible key is simply impossible. • Nevertheless, hash tables store their data in an array, and the array index where a key is stored is based on the key.

  15. Hash Tables (5) • The index is not equal to the key, but it is computed from the key. • The array index for a key is called the hash code for that key. • A function that computes a hash code, given a key, is called a hash function. • To find a key in a hash table, you just have to compute the hash code of the key and go directly to the array location given by that hash code. • If the hash code is 17, look in array location number 17. • Now, since there are fewer array locations than there are possible keys, it's possible that we might try to store two or more keys in the same array location.

  16. Hash Tables (6) • This is called a collision. • A collision is not an error. • We can't reject a key just because another key happened to have the same hash code. • A hash table must be able to handle collisions in some reasonable way. • In the type of hash table that is used in Java, each array location actually holds a linked list of key/value pairs (possibly an empty list). • When two items have the same hash code, they are in the same linked list. The structure of the hash table looks something like this:

  17. Note on Thread-Safe Collections • Concurrent applications mean that a collection could be processed simultaneously by several threads • This can lead to problems! • Java provides some thread-safe implementations in java.util.concurrent 9-18

More Related