Dictionaries Collection of pairs. (key, element) Pairs have different keys E.g. a pair contains two components, student id and name (1234, Nan) (2345, Charlie) Etc.
Dictionaries (theKey, theElement) (1234, Nan) (2345, Lauren) Operations. find(theKey) find the pair with a specified key erase(theKey) delete the pair with a specified key insert(theKey, theElement)
Application Collection of student records in this class. (key, element) = (student name, linear list of assignment and exam scores) All keys are distinct. Elements are in ascending order of key Get the element whose key is Stephen. Update the element whose key is Garrick. insert(Key, element) implemented as update when there is already a pair with the given key. If a pair with the given key exists, return false. erase() followed by insert().
Application Collection of student records in this class. (key, element) = (student name, linear list of assignment and exam scores) All keys are distinct. Elements are in ascending order of key Get the element whose key is Stephen. Update the element whose key is Garrick. insert(Key, element) implemented as update when there is already a pair with the given key. If a pair with the given key exists, return false. erase() followed by insert().
Dictionary With Duplicates Keys are not required to be distinct. Word dictionary. Pairs are of the form (word, meaning). May have two or more entries for the same word. (bolt, a threaded pin) (bolt, a crash of thunder) (bolt, to shoot forth suddenly) (bolt, a gulp) (bolt, a standard roll of cloth) etc.
Pair template struct pair { T1 first; T2 second; // constructer pair() : first(T1()), second(T2()) {} pair(const T1& x, const T2& y) : first(x), second(y) {} // copy constructer template pair (const pair &p) : first(p.first), second(p.second) { } }
example
Make_pair template pair make_pair (T1 x, T2 y) { return ( pair (x,y) ); }
Represent As A Linear List L = (e 0, e 1, e 2, e 3, …, e n-1 ) Each e i is a pair (key, element). 5-pair dictionary D = (a, b, c, d, e). a = (aKey, aElement), b = (bKey, bElement), etc. Array or linked representation.
Array Representation abcde Sorted Array ABCDE elements are in ascending order of key 5-pair dictionary D = (a, b, c, d, e). a = (aKey, aElement), b = (bKey, bElement), etc.
Unsorted Chain abcde NULL firstNode Sorted Chain ABCDE NULL firstNode Elements are in ascending order of Key.
Lab 3 SortedArray derived from dictionary will be provided sortedChain (interface) derived from dictionary will be provided Students will be asked to implement the member functions of sortedChain. Test program will be provided
C++ STL map Unique key values: no two elements in the map have keys that compare equal to each other. A similar associative container allowing for multiple elements with equivalent keys, multimap. multimap
C++ map Maps are a kind of associative containers that stores elements formed by the combination of a key value and a mapped value. the key value is generally used to uniquely identify the element, while the mapped value is some sort of value associated to this key. Types of key and mapped value may differ
C++ map
constructor Element access: operator[]
Operator =
begin() & end()
empty()
size()
[]
Insert()
Erase()
Swap()
Clear()
Find()
Count() a is an element of mymap. b is not an element of mymap. c is an element of mymap. d is not an element of mymap. e is not an element of mymap. f is an element of mymap. g is not an element of mymap.
lower_bound() and upper_bound() a => 20 e => 100
Equal_range()
multimap timap/