Introduktion til datastrukturer. Introduktion til datastrukturer. Introduktion til datastrukturer. Datastrukturer
|
|
|
- Troels Fog
- 8 år siden
- Visninger:
Transkript
1 Introduktion til datastrukturer Introduktion til datastrukturer Philip Bille Datastrukturer Datastruktur. Metode til at organise data så det kan søges i/tilgås/manipuleres effektivt. Mål. Hurtig Kompakt Terminologi. Abstrakt vs. konkret datastruktur. Dynamisk vs. statisk datastruktur. Introduktion til datastrukturer
2 Stak Stak. Vedligehold en dynamisk sekvens (stakken) S af elementer under følgende operationer. PUSH(x): tilføj et nyt element x til S. POP(): fjern og returner det seneste tilføjede element i S. ISEMPTY(): returner sand hvis S ikke indeholder nogle elementer PUSH(28) 16 POP() 16 POP() 16 PUSH(7) 7 16 Kø Kø. Vedligehold en dynamisk sekvens (køen) K af elementer under følgende operationer. ENQUEUE(x): tilføj et nyt element x til K DEQUEUE(): fjern og returner det tidligst tilføjede element i K. ISEMPTY(): returner sand hvis K ikke indeholder nogle elementer ENQUEUE(1) ENQUEUE(22) DEQUEUE() DEQUEUE() ENQUEUE(6) Anvendelser Stakke. Virtuelle maskiner Parsing Funktionskald Backtracking Køer. Skedulering af processer Buffering Breddeførst søgning Implementation af stak med tabel Stak. Stak med kapacitet N vha. tabel. Datastruktur. Tabel S[0..N-1] Index top i S. Operationer. PUSH(x): Tilføj x på S[top+1], sæt top = top + 1 POP(): returner S[top], sæt top = top - 1 ISEMPTY(): returner sand hvis og kun hvis top = -1. Tjek for overløb og underløb i PUSH og POP top
3 PUSH POP Implementation af stak med tabel top top Tid. PUSH i Θ(1) tid. POP i Θ(1) tid. ISEMPTY i Θ(1) tid. Plads. Θ(N) plads. Mangler. Vi skal kende kapacitet N fra start. Vi spilder plads når antal elementer er << N. Implementation af kø med tabel Kø. Kø med kapacitet N vha. tabel. ENQUEUE DEQUEUE20 9 Datastruktur. Tabel S[0..N-1] Indeks (tidligst indsatte element) og tail (næste ledige element) i S og tæller count (antal elementer i kø). Operationer. ENQUEUE(x): Tilføj x på S[tail], opdater count og tail cyklisk. DEQUEUE(): returner S[], opdater count og cyklisk. ISEMPTY(): returner sand hvis og kun hvis count = 0. Tjek for overløb og underløb i DEQUEUE og ENQUEUE tail count = tail
4 Implementation af kø med tabel Stakke og køer count = Stak. Tid. PUSH, POP, ISEMPTY i Θ(1) tid. Plads. Θ(N) top Tid. ENQUEUE i Θ(1) tid. tail Kø. Tid. ENQUEUE, Dequeue, ISEMPTY i Θ(1) tid. Plads. Θ(N) count = tail DEQUEUE i Θ(1) tid. ISEMPTY i Θ(1) tid. Udfordring. Kan vi komme ned på lineær plads med samme tid? Plads. Θ(N) plads. Mangler. Vi skal kende kapacitet N fra start. Vi spilder plads når antal elementer er << N. Hægtede lister (linked lists) Introduktion til datastrukturer. Datastruktur til at vedligeholde en dynamisk sekvens af elementer i lineær plads. Rækkefølge af elementer bestemt af referencer/pegere kaldet hægter. Effektiv at indsætte og fjerne elementer eller sammenhængende dele af elementer. Dobbelt-hægtede vs enkelt-hægtede null null null
5 Hægtede lister Hægtede lister Dobbelt-hægtede lister i Java. Simple operationer. class Node { int key; Node next; Node prev; prev key next SEARCH(, k): returner knude med værdi k i listen. Returner null hvis den ikke findes. INSERT(, x): indsæt knude x i starten af listen. Returner ny. DELETE(, x): fjern knude x i listen. Node = new Node(); Node b = new Node(); Node c = new Node();.key = 7; b.key = 2; c.key = ;.prev = null;.next = b; b.prev = ; b.next = c; c.prev = b; c.next = null; b c null 7 null null 2 null null null b c null 7 2 null null null null Hægtede lister Operationer på dobbelthægtet liste i Java. Node Search(Node, int value) { Node x = ; while (x!= null) { if (x.key == value) return x; x = x.next; return null; Node Insert(Node, Node x) { x.prev = null; x.next = ;.prev = x; return x; Node Delete(Node, Node x) { if (x.prev!= null) x.prev.next = x.next; else = x.next; if (x.next!= null) x.next.prev = x.prev; return ; null null Hægtede lister null null null Tid. Hvor hurtigt kører operationerne? SEARCH i Θ(n) tid INSERT og DELETE i Θ(1) tid. Plads. Θ(n) Opgave. Lad p være en ny knude med værdien 10 og lad q være knuden i listen med værdi 2. Håndkør Search(,), Insert(,p) og Delete(,q).
6 Implementation af stak og kø med hægtede lister Opgave. Overvej hvordan man kan implementere stakke og køer med hægtede lister effektivt. Stak. Vedligehold en dynamisk sekvens (stakken) S af elementer under følgende operationer. PUSH(x): tilføj et nyt element x til S. POP(): fjern og returner det seneste tilføjede element i S. ISEMPTY(): returner sand hvis S ikke indeholder nogle elementer. Stakke og køer Stak og kø implementeret med hægtet liste Stak. Tid. PUSH, POP, ISEMPTY i Θ(1) tid. Plads. Θ(n) Kø. Tid. ENQUEUE, Dequeue, ISEMPTY i Θ(1) tid. Plads. Θ(n) Kø. Vedligehold en dynamisk sekvens (køen) K af elementer under følgende operationer. ENQUEUE(x): tilføj et nyt element x til K DEQUEUE(): fjern og returner det tidligst tilføjede element i K. ISEMPTY(): returner sand hvis K ikke indeholder nogle elementer. Hægtede lister Hægtet liste. Fleksibel datastruktur til at vedligeholde en sekvens af elementer i lineær plads. Andre hægtede datastrukturer. Cykliske lister, træer, grafer, null 1 root 8 null 15 Introduktion til datastrukturer 20 null null 1 null 11 1 null null null 11 1 null null
7 Stak med dynamisk tabel Udfordring. Kan vi implementere en stak effektivt med tabel(ler)? Behøver vi fastsætte en øvre grænse på antallet af elementer? Kan vi komme ned på lineær plads og konstant tid? Dynamiske tabeller Mål. Implementer en stak vha. tabel(ler) i Θ(n) plads for n elementer. Så hurtige operationer som muligt. Kun fokus på PUSH. Ignorer POP og ISEMPTY indtil videre. Løsning 1. Start med tabel af størrelse 1. PUSH(x): Opret ny tabel af størrelse +1. Flyt alle elementer til ny tabel. Slet gammel tabel. Dynamiske tabeller PUSH(x): Opret ny tabel af størrelse +1. Flyt alle elementer til ny tabel. Slet gammel tabel. Tid. Hvor meget tid tager n PUSH operationer? PUSH i tager Θ(i) tid: byg tabel af størrelse i, flyt i-1, elementer og indsæt nyt element. Samlet tid n = Θ(n 2 ) Plads. Θ(n) Dynamiske tabeller Ide. Kopier kun elementer en gang i mellem. Løsning 2. Start med tabel af størrelse 1. PUSH(x): Hvis tabel er fuld (antallet af elementer i stak er lig tabellens størrelse). Opret ny tabel af dobbelt størrelse. Flyt elementer over i ny tabel. Slet gammel tabel. Udfordring. Kan vi gøre noget smartere?
8 Dynamiske tabeller PUSH(x): Hvis tabel er fuld (antallet af elementer i stak er lig tabellens størrelse). Opret ny tabel af dobbelt størrelse. Flyt elementer over i ny tabel. Slet gammel tabel. Tid. Hvor meget tid tager n PUSH operationer? PUSH 2 k tager Θ(2 k ) tid: byg tabel af størrelse 2 k+1, flyt 2 k elementer og indsæt nyt element. Alle andre PUSH tager Θ(1) tid. Samlet tid log n + n = Θ(n) Plads. Θ(n) Dynamiske tabeller Stak med dynamisk tabel. n PUSH operationer i Θ(n) tid og plads. Kan udvides til n PUSH, POP og ISEMPTY operationer i Θ(n) tid. Køretiden er amortiseret Θ(1) per operation (een operation kan tage lang tid, men tiden for enhver sekvens af k operationer er Θ(k)) Med snedige tricks kan man deamortisere løsning til Θ(1) værstefaldskøretid per operation. Kø med dynamisk tabel. Samme resultater som stak. Global genobygning. Dynamisk tabel er eksempel på global genopbygning (global rebuilding). General teknik til at gøre statiske datastrukturer dynamiske. Stakke og køer Datastruktur PUSH POP ISEMPTY Plads Tabel med kapacitet N Θ(1) Θ(1) Θ(1) Θ(N) Hægtet liste Θ(1) Θ(1) Θ(1) Θ(n) Dynamisk tabel med udvidelse Θ(n) Θ(1) Θ(1) Θ(n) Dynamisk tabel med fordobling Θ(1) Θ(1) Θ(1) Θ(n) Dynamisk tabel med deamortiseret fordobling = amortiseret Θ(1) Θ(1) Θ(1) Θ(n) Introduktion til datastrukturer
Introduktion til datastrukturer. Introduktion til datastrukturer. Introduktion til datastrukturer. Datastrukturer
Introduktion til datastrukturer Introduktion til datastrukturer Philip Bille Datastrukturer Datastruktur. Metode til at organise data så det kan søges i/tilgås/manipuleres effektivt. Mål. Hurtig Kompakt
Prioritetskøer og hobe. Philip Bille
Prioritetskøer og hobe Philip Bille Plan Prioritetskøer Træer Hobe Repræsentation Prioritetskøoperationer Konstruktion af hob Hobsortering Prioritetskøer Prioritetskø Vedligehold en dynamisk mængde S af
02105 Eksamensnoter. Lasse Herskind S maj Sortering 3
02105 Eksamensnoter Lasse Herskind S153746 12. maj 2017 Indhold 1 Sortering 3 2 Analyse af algoritme 4 2.1 Køretid.......................................... 4 2.2 Pladsforbrug.......................................
Binære søgetræer. Binære søgetræer. Nærmeste naboer. Nærmeste nabo
Philip Bille Nærmeste naboer. Vedligehold en dynamisk mængde S af elementer. Hvert element har en nøgle key[] og satellitdata data[]. operationer. PREDECESSOR(k): returner element med største nøgle k.
Binære søgetræer. Binære søgetræer. Nærmeste naboer. Nærmeste nabo
Philip Bille er. Vedligehold en dynamisk mængde S af elementer. Hvert element har en nøgle x.key og satellitdata x.data. operationer. PREDECESSOR(k): returner element x med største nøgle k. SUCCESSOR(k):
Hashing. Ordbøger Hægtet hashing Hashfunktioner Lineær probering. Philip Bille
Hashing Ordbøger Hægtet hashing Hashfunktioner Lineær probering Philip Bille Hashing Ordbøger Hægtet hashing Hashfunktioner Lineær probering Ordbøger Ordbøger. Vedligehold en dynamisk mængde S af elementer.
Danmarks Tekniske Universitet
side af sider Danmarks Tekniske Universitet Skriftlig prøve, den 6. maj 0. Kursusnavn: Algoritmer og datastrukturer I Kursus nr. 005. Tilladte hjælpemidler: Skriftlige hjælpemidler. Varighed: timer Vægtning
Algoritmer og datastrukturer Course No. 02105 Cheat Sheet 2012. May 15, 2012
Algoritmer og datastrukturer Course No. 02105 Cheat Sheet 2012 May 15, 2012 1 CONTENTS 2012 CONTENTS Contents 1 Kompleksitet 3 1.1 Køretid................................................ 3 1.2 Asymptotisk
Introduktion. Algoritmer og datastrukturer Toppunkter Algoritme 1 Algoritme 2 Algoritme 3. Philip Bille
Introduktion Algoritmer og datastrukturer Toppunkter Algoritme 1 Algoritme 2 Algoritme 3 Philip Bille Introduktion Algoritmer og datastrukturer Toppunkter Algoritme 1 Algoritme 2 Algoritme 3 Algoritmer
Mindste udspændende træ. Mindste udspændende træ. Introduktion. Introduktion
Philip Bille Introduktion (MST). Udspændende træ af minimal samlet vægt. Introduktion (MST). Udspændende træ af minimal samlet vægt. 0 0 Graf G Ikke sammenhængende Introduktion (MST). Udspændende træ af
Danmarks Tekniske Universitet
Eksamen 02105, F14 side 1 af 14 Danmarks Tekniske Universitet Skriftlig prøve, den 22. maj 2014. Kursusnavn: Algoritmer og datastrukturer 1 Kursusnummer: 02105 Hjælpemidler: Skriftlige hjælpemidler. Det
Danmarks Tekniske Universitet
side af sider Danmarks Tekniske Universitet Skriftlig prøve, den 6. maj 0. Kursusnavn: Algoritmer og datastrukturer Kursus nr. 06. Tilladte hjælpemidler: Skriftlige hjælpemidler. Varighed: timer Vægtning
Introduktion. Introduktion. Algoritmer og datastrukturer. Eksempel: Maksimalt tal
Philip Bille Algoritmer og datastrukturer Algoritmisk problem. Præcist defineret relation mellem input og output. Algoritme. Metode til at løse et algoritmisk problem. Beskrevet i diskrete og entydige
Forén og find. Introduktion Hurtig find Hurtig forening Vægtet forening Stikompression Dynamiske sammenhængskomponenter.
Forén og find Introduktion Hurtig find Hurtig forening Vægtet forening Stikompression Dynamiske sammenhængskomponenter Philip Bille Forén og find Introduktion Hurtig find Hurtig forening Vægtet forening
1. Redegør for Lister, stakke og køer mht struktur og komplexitet af de relevante operationer
1. Redegør for Lister, stakke og køer mht struktur og komplexitet af de relevante operationer på disse. Typer af lister: Array Enkelt linket liste Dobbelt linket Cirkulære lister Typer af køer: FILO FIFO
Abstrakte datatyper C#-version
Note til Programmeringsteknologi Akademiuddannelsen i Informationsteknologi Abstrakte datatyper C#-version Finn Nordbjerg 1/9 Abstrakte Datatyper Denne note introducerer kort begrebet abstrakt datatype
Søgning og Sortering. Søgning og Sortering. Søgning. Linæer søgning
Søgning og Sortering Søgning og Sortering Philip Bille Søgning. Givet en sorteret tabel A og et tal x, afgør om der findes indgang i, så A[i] = x. Sorteret tabel. En tabel A[0..n-1] er sorteret hvis A[0]
Søgning og Sortering. Søgning Linæer søgning Binær søgning Sortering Indsættelsessortering Flettesortering. Philip Bille
Søgning og Sortering Søgning Linæer søgning Binær søgning Sortering Indsættelsessortering Flettesortering Philip Bille Søgning og Sortering Søgning Linæer søgning Binær søgning Sortering Indsættelsessortering
Mindste udspændende træ
Mindste udspændende træ Introduktion Repræsentation af vægtede grafer Egenskaber for mindste udspændende træer Prims algoritme Kruskals algoritme Philip Bille Mindste udspændende træ Introduktion Repræsentation
Skriftlig eksamen i Datalogi
Roskilde Universitetscenter Skriftlig eksamen i Datalogi Modul 1 Sommer 1999 Opgavesættet består af 5 opgaver, der ved bedømmelsen tillægges følgende vægte: Opgave 1 15% Opgave 2 15% Opgave 3 8% Opgave
DM507 Algoritmer og datastrukturer
DM507 Algoritmer og datastrukturer Forår 2012 Projekt, del II Institut for matematik og datalogi Syddansk Universitet 15. marts, 2012 Dette projekt udleveres i tre dele. Hver del har sin deadline, således
Korteste veje. Introduktion Egenskaber for korteste veje Dijkstras algoritme Korteste veje på DAGs. Philip Bille
Korteste veje Introduktion Egenskaber for korteste veje Dijkstras algoritme Korteste veje på DAGs Philip Bille Korteste veje Introduktion Egenskaber for korteste veje Dijkstras algoritme Korteste veje
Programmeringscamp. Implementer funktionerne én for én og test hele tiden.
Programmeringscamp De to opgaver træner begge i at lave moduler som tilbyder services der kan bruges af andre, samt i at implementere services efter en abstrakt forskrift. Opgave 1 beder jer om at implementere
Dynamisk programmering
Dynamisk programmering Dynamisk programmering Optimeringsproblem: man ønsker at finde bedste den kombinatoriske struktur blandt mange mulige. Dynamisk programmering Optimeringsproblem: man ønsker at finde
Danmarks Tekniske Universitet
Eksamen 005, F side af sider Danmarks Tekniske Universitet Skriftlig prøve, den 6. maj 0. Kursusnavn: Algoritmer og datastrukturer I Kursus nr. 005. Tilladte hjælpemidler: Skriftlige hjælpemidler. Varighed:
Søgning og Sortering. Philip Bille
Søgning og Sortering Philip Bille Plan Søgning Linæer søgning Binær søgning Sortering Indsættelsesortering Flettesortering Søgning Søgning 1 4 7 12 16 18 25 28 31 33 36 42 45 47 50 1 2 3 4 5 6 7 8 9 10
Analyse af algoritmer
Analyse af algoritmer Analyse af algoritmer Køretid Pladsforbrug Asymptotisk notation O, Θ og Ω-notation. Eksperimentiel analyse af algoritmer Philip Bille Analyse af algoritmer Analyse af algoritmer Køretid
Analyse af algoritmer. Analyse af algoritmer. Analyse af algoritmer. Køretid
Philip Bille Mål. At bestemme og forudsige resourceforbrug og korrekthed af algoritmer Eks. Virker min algoritme til at beregne korteste veje i grafer? Hvor hurtigt kører min algoritme til at søge efter
Algoritmeskabeloner: Sweep- og søgealgoritmer C#-version
Note til Programmeringsteknologi Akademiuddannelsen i Informationsteknologi Algoritmeskabeloner: Sweep- og søgealgoritmer C#-version Finn Nordbjerg 1/9 Indledning I det følgende introduceres et par abstrakte
Tilgang til data. To udbredte metoder for at tilgå data: Sekventiel tilgang Random access: tilgang via ID (også kaldet key, nøgle) for dataelementer.
Merging og Hashing Tilgang til data To udbredte metoder for at tilgå data: Sekventiel tilgang Random access: tilgang via ID (også kaldet key, nøgle) for dataelementer. API for sekventiel tilgang (API =
Skriftlig Eksamen DM507 Algoritmer og Datastrukturer
Skriftlig Eksamen DM507 Algoritmer og Datastrukturer Institut for Matematik og Datalogi Syddansk Universitet, Odense Mandag den 6. juni 2016, kl. 15:00 19:00 Besvarelsen skal afleveres elektronisk. Se
DM507 Algoritmer og datastrukturer
DM507 Algoritmer og datastrukturer Forår 2010 Projekt, del III Institut for matematik og datalogi Syddansk Universitet 24. april, 2010 (let justeret 10. maj og 21. maj 2010) Dette projekt udleveres i tre
DM507 Algoritmer og datastrukturer
DM507 Algoritmer og datastrukturer Forår 2012 Projekt, del III Institut for matematik og datalogi Syddansk Universitet 29. april, 2012 Dette projekt udleveres i tre dele. Hver del har sin deadline, således
Skriftlig Eksamen Algoritmer og Datastrukturer (DM507)
Skriftlig Eksamen Algoritmer og Datastrukturer (DM507) Institut for Matematik og Datalogi Syddansk Universitet, Odense Onsdag den 0. juni 009, kl. 9 Alle sædvanlige hjælpemidler (lærebøger, notater, osv.)
Grådige algoritmer. Et algoritme-konstruktionsprincip ( paradigme ) for optimeringsproblemer.
Grådige algoritmer Grådige algoritmer Et algoritme-konstruktionsprincip ( paradigme ) for optimeringsproblemer. Grådige algoritmer Et algoritme-konstruktionsprincip ( paradigme ) for optimeringsproblemer.
Grafer og graf-gennemløb
Grafer og graf-gennemløb Grafer En mængde V af knuder (vertices). En mængde E V V af kanter (edges). Dvs. ordnede par af knuder. Figur: Terminologi: n = V, m = E (eller V og E (mis)bruges som V og E ).
Plan. Introduktion. Eks: Max i tabel. Algoritmer og datastrukturer. Algoritmer og datastrukturer. Toppunkter. Algoritme 1. Algoritme 2.
Plan Algoritmer og datastrukturer Toppunkter Introduktion Philip Bille Algoritme Algoritme Algoritme Algoritmer og datastrukturer Eks: Max i tabel Hvad er det? Algoritmisk problem: præcist defineret relation
Danmarks Tekniske Universitet
side af sider Danmarks Tekniske Universitet Skriftlig prøve, den. maj 00. Kursusnavn Algoritmer og datastrukturer Kursus nr. 06. Tilladte hjælpemidler: Alle hjælpemidler. Vægtning af opgaverne: Opgave
Løsning af møntproblemet
Løsning af møntproblemet Keld Helsgaun RUC, oktober 1999 Antag at tilstandene i problemet (stillingerne) er repræsenteret ved objekter af klassen State. Vi kan da finde en kortest mulig løsning af problemet
