Download præsentationen
Præsentation er lastning. Vent venligst
Offentliggjort afJohanne Kristensen Redigeret for ca. et år siden
1
Algoritmer og Datastrukturer 1 Union-Find [CLRS, kapitel 21.2-21.3] Gerth Stølting Brodal Aarhus Universitet
2
Union-Find MakeSet( S, x ) Union( x, y ) FindSet( x ) Opret en ny mængde { x } Erstat S x ={...,x,... } S y ={...,x,... } med S x U S y ={...,x,...,y,... } Retuner en repræsentant for S x ={...,x,... } FindSet( x )=FindSet( y ) hvis og kun hvis x og y er i samme mængde
3
Trærepræsentation (I) Mængde = enkelt kædet liste MakeSet = lav en ny knude FindSet = retuner sidste knude Union = konkatener listerne MakeSet( S, x ) O(1) Union( x, y ) O(|S x |+|S y |) FindSet( x ) O(|S x |)
4
Trærepræsentation (II) Mængde = enkelt kædet liste MakeSet = lav en ny knude FindSet = retuner sidste knude Union = konkatener listerne og opdater pointerne MakeSet( S, x ) O(1) Union( x, y ) O(min(|S x |,|S y |)) FindSet( x ) O(1)
5
Sekvens af Union Sætning Et sekvens af n union operationer tager tid højest O(n·log n) Bevis Hver pointer flyttes højest log n gange (hver gang til en liste der mindst er dobbelt så stor)
6
Trærepræsentation Union Mængde = træ MakeSet = lav en ny knude FindSet = retuner roden Union = Sæt det ”lille” træ under roden af det ”store” træ
7
Stikomprimering stikomprimering
8
Lemma height[x] ≤ rank[x] size[x] ≥ 2 rank[x] Bevis Induktion. MakeSet( S, x ) O(1) Union( x, y ) O((log |S x |)+(log |S y |)) FindSet( x ) O(log |S x |) (Ovenstående udnytter kun linking by rank) Analyse af Trærepræsentation med Rank-Linkning
9
Analyse af Trærepræsentation med Stikomprimering Sætning En sekvens af m Union-Find operation på n elementer tager tid O(m·α(n)) hvor α(n) er den Inverse til Ackerman funktionen ([CLRS], kapitel 21.4) som for alle praktiske formål α(n)≤4.
Lignende præsentationer
© 2024 SlidePlayer.dk Inc.
All rights reserved.