Föreläsning 5 ADT Set, Map, Dictionary. Iteratorer TDDD86: DALGP Utskriftsversion av föreläsning i Datastrukturer, algoritmer och programmeringsparadigm 11 september 2015 Tommy Färnqvist, IDA, Linköpings universitet 5.1 Innehåll Innehåll 1 Symboltabeller 1 1.1 Abstrakta datatyper...................................... 1 1.2 Associativa containrar i C++................................. 2 2 Iteratorer 4 5.2 1 Symboltabeller Symboltabeller Abstraktion av nyckel-värdepar Sätt in ett värde med specificerad nyckel Givet en nyckel, sök efter motsvarande värde 5.3 1.1 Abstrakta datatyper ADT Set Domän: mängder av nycklar ADT Map size() antalet nycklar i mängden contains(k) returnera true om k finns i mängden, annars false put(k) lägg till k till mängden remove(k) ta bort k från mängden Domän: mängder av poster/par (nyckel, värde) Mängderna är partiella funktioner som avbildar nycklar på värden! size() antalet par i mängden get(k) hämta informationen associerad med k eller null om någon sådan nyckel inte finns put(k,v) lägg till (k,v) till mängden och returnera null om k är ny; ersätt annars värdet med v och returnera det gamla värdet remove(k) ta bort post (k,v) och returnera v; returnera null om mängden inte har någon sådan post 5.4 5.5 1
ADT Map Exempel: Kursdatabas: (kod, namn) Associativt minne (adress, värde) Gles matris: ((rad, kolumn), värde) Lunchmeny: (dag, rätt) Statisk Map: inga uppdateringar tillåtna Dynamisk Map: uppdateringar är tillåtna ADT Dictionary Domän: mängder av par (nyckel, värde) Mängderna är relationer mellan nycklar och värden! ADT Dictionary size() antalet par i mängden find(k) returnera någon post med nyckel k eller null om inget sådant par finns findall(k) returnera en itererbar samling av alla poster med nyckel k insert(k,v) lägg till (k,v) och returnera den nya posten remove(k,v) ta bort och returnera paret (k,v); returnera null om det inte finns något sådant par entries() returnera itererbar samling av alla poster Exempel: Svensk-engelskt lexikon..., (jakt, yacht), (jakt, hunting),... Telefonkatalog (flera nummer tillåtna) Relation mellan liuid och avklarade kurser Lunchmeny (med flera val): (dag, rätt) Statisk Dictionary: inga uppdateringar tillåtna Dynamisk Dictionary: uppdateringar är tillåtna 5.6 5.7 5.8 1.2 Associativa containrar i C++ Associativa containrar Snabb åtkomst till data baserat på söknycklar följande associativa containrar är ordnade itererar man över dem erhålles elementen i nyckelordning map multimap set multiset set-containrar lagrar enbart nycklar map-containrar lagrar nyckel-värdepar - använder pair för att lagra en nyckel och ett associerat värde icke-multivarianterna tillåter enbart unika nycklar dessutom finns motsvaranade oordnade associativa containrar unordered_map unordered_multimap unordered_set unordered_multiset 5.9 Klassen pair Klass för att lagra värdepar används till exempel av alla map-containrar. har hjälpfunktionen make_pair för att skapa pair-objekt vector< pair<int, string> > v; int i = 4711; string s = "foobar"; v.push_back(make_pair(i, s)); det är enkelt att komma åt parets innehåll: pair<int, string> mypair; mypair.first = 4711; mypair.second = "foobar"; // samma som pair<int, string>(i, s); 5.10 2
Associativa containrar operationer 5.11 Associativa containrar operationer 5.12 Associativa containrar operationer 5.13 Övning räkna unika ord Skriv ett program som räknar antalet unika ord i en stor textfil 5.14 Övning räkna ord Skriv ett program som avgör vilket ord som är vanligast i en stor textfil 5.15 3
Övning anagram Skriv ett program som beräknar den största anagrammängden från en ordlista 5.16 2 Iteratorer Iterator 5.17 Containeriteratorer 5.18 Iteratorpositioner 5.19 4
Iteratorkategorier 5.20 Operationer på iteratorer 5.21 Exempel iteratoroperationer 5.22 5