Hem Personliga finanser Binära hål och binära sökträd används i algoritmer - dummies

Binära hål och binära sökträd används i algoritmer - dummies

Video: Svensk skola: 175 år av ofrihet - Rickard Dahlin - Freedomfest 2017 2024

Video: Svensk skola: 175 år av ofrihet - Rickard Dahlin - Freedomfest 2017 2024
Anonim

En särskild typ av trädstruktur är binärhöga, som placerar var och en av nodelementen i en särskild ordning. Sök träd gör att du snabbt kan leta efter data. Att skaffa dataobjekt, placera dem i sorterad ordning i ett träd, och sedan söka det träd är ett av de snabbare sätten att hitta information.

I en binär hög innehåller roddnoden alltid det minsta värdet. När du tittar på grenarna ser du att övre grenar alltid är ett mindre värde än grenar och löv på lägre nivåer. Effekten är att hålla trädet balanserat och i en förutsägbar ordning så att sökningen blir extremt effektiv. Kostnaden är att hålla trädet balanserat.

Av alla uppgifter som applikationer gör, är sökning mer tidskrävande och den som krävde mest. Även om du lägger till data (och sorterar det senare) kräver lite tid, kommer fördelen att skapa och behålla en dataset från att använda den för att utföra användbart arbete, vilket innebär att du söker efter viktig information. Följaktligen kan du ibland klara av med mindre effektiv CRUD-funktionalitet och till och med en mindre än optimal sortrutin, men sökningar måste gå så effektivt som möjligt. Det enda problemet är att ingen sökning utför varje uppgift med absolut effektivitet, så du måste väga dina alternativ baserat på vad du förväntar dig att göra som en del av sökrutinerna.

Två av de mer effektiva sökmetoderna innefattar användningen av binärt sökträd (BST) och binärt hål. Båda sökteknikerna är beroende av en trädliknande struktur för att hålla nycklarna som används för att få tillgång till dataelement. Arrangemanget av de två metoderna är emellertid annorlunda, varför man har fördelar över den andra när man utför vissa uppgifter. Denna figur visar arrangemanget för en BST.

Arrangemang av nycklar när du använder en BST.

Observera hur tangenterna följer en ordning i vilka färre tal visas till vänster och större siffror visas till höger. Rotenoden innehåller ett värde som ligger i mitten av nivån av nycklar, vilket ger BST ett lätt förstått balanserat sätt att lagra nycklarna. Kontrastera detta arrangemang till den binära höjden som visas här.

Arrangemang av nycklar när man använder en binär hög.

Varje nivå innehåller värden som är mindre än föregående nivå, och roten innehåller det högsta nyckelvärdet för trädet. Dessutom, i det här fallet visas de mindre värdena till vänster och ju större till höger (även om denna order inte är strikt tillämpad). Figuren visar faktiskt en binär maxhöga. Du kan även skapa en binär minhögdjup, där roten innehåller lägsta nyckelvärde och varje nivå bygger till högre värden, med de högsta värdena som visas i bladet.

Som tidigare nämnts har BST några fördelar jämfört med binärhöga när den används för att utföra en sökning. Följande lista ger några av höjdpunkterna i dessa fördelar:

  • Sökning efter ett element kräver O (log n) tid, i motsats till O (n) tid för ett binärt hål.
  • Skriv ut elementen i ordning kräver endast O (log n) tid, i motsats till O (n log n) tid för en binär hög.
  • Att hitta golvet och taket kräver O (log n) tid.
  • Att hitta Kth minsta / största elementet kräver O (log n) tid när trädet är korrekt konfigurerat.

Om dessa tider är viktiga beror på din ansökan. BST tenderar att fungera bäst i situationer där du spenderar mer tid på att söka och mindre tid att bygga trädet. En binär hög har en tendens att fungera bäst i dynamiska situationer där nycklarna ändras regelbundet. Binärhöget erbjuder också fördelar, som beskrivs i följande lista:

  • Skapa de nödvändiga strukturerna kräver färre resurser eftersom binära hällor är beroende av arrays, vilket gör dem också cachevänligare.
  • Att bygga ett binärt hål kräver O (n) tid, i motsats till BST, vilket kräver O (n log n) tid.
  • Det är inte nödvändigt att använda pekare för att implementera trädet.
  • Beroende på binära höjdsvariationer (till exempel Fibonacci Heap) erbjuder fördelar som ökning och minskning av viktiga tider av O (1) tid.
Binära hål och binära sökträd används i algoritmer - dummies

Redaktörens val

Fastighetsprofessionens grunder för fastighetslicensexamen - dummies

Fastighetsprofessionens grunder för fastighetslicensexamen - dummies

Fastighetsexamen kommer att förvänta dig att du har ett grundläggande grepp på fastighetsbranschen. Du tror att det bara är uppenbart att veta vad de viktigaste spelarna gör i en fastighetsaffär, men på grund av den terminologi de delar, blir skillnaderna mellan spelarna lite muddlade. Här är snabba beskrivningar ...

Kostnadsmetoden för fastighetslicensexamen - dummies

Kostnadsmetoden för fastighetslicensexamen - dummies

En metod för att uppskatta Värdet på fastigheter kallas kostnaden. Du måste känna till formeln för fastighetslicensexamen. Kostnadsmetoden baseras på tanken att komponenterna i en fastighet eller marken och byggnaderna kan läggas till för att komma fram till ...

Studie för fastighetslicensexamen - dummies

Studie för fastighetslicensexamen - dummies

När var sista gången du tog en multipelvalsexamen ? Eller, för den delen, någon examen? Det är troligt att det var länge sedan. Kanske överväger du huruvida du ska bli en fastighetsmäklare, men du är lite avskräckt av tanken på att du måste göra ett test. Vad du kan ...

Redaktörens val

Följer ett basketspel på tv - dummies

Följer ett basketspel på tv - dummies

Du kommer bli mycket mer ute av att titta på ett basketspel på TV - eller till och med leva - om du gör mer än att se bollen gå in i rammen. Kolla in dessa insider tips för att fånga den verkliga åtgärden och öka din njutning av sporten. Förutse nästa pass Försök att tänka som ...

Top 5 Fantasy Basketball League Sites - Dummies

Top 5 Fantasy Basketball League Sites - Dummies

Att hitta och gå med på en fantasy basketplats kan ibland vara skrämmande uppgift eftersom så många alternativ är tillgängliga och de flesta webbplatser ser lika ut. Bara för att webbplatser ser ut som det betyder inte nödvändigtvis att de mäter i värde. Vissa webbplatser erbjuder gratis ligor, andra betalade - och vissa webbplatser tillhandahåller bara standard liga ...

Tryck på motståndarna i Basket - Dummies

Tryck på motståndarna i Basket - Dummies

Pressen är kort för tryck. Ofta kallad en fullrättspress, det här är ett anfallande försvar som används på backen, där målet är att tvinga en omsättning. Vanligtvis används efter en gjord korg, svänger pressgruppen över motståndarna i backcourt; Om motståndarna lyckas få bollen förbi halvvägs (kallad brytning ...

Redaktörens val

Hur R beräknar oändliga, odefinierade och saknade värden - dummies

Hur R beräknar oändliga, odefinierade och saknade värden - dummies

Lyckligtvis kan R hantera dataanomalier som förvirrar några andra statistiska plattformar. I vissa fall har du inte reella värden att beräkna med. I de flesta verkliga dataset saknas faktiskt åtminstone några värden. Dessutom har vissa beräkningar oändlighet som ett resultat (som att dividera med noll) eller kan inte ...

Hur man lägger till linjer i en plot i R-dummies

Hur man lägger till linjer i en plot i R-dummies

I R, lägger du till rader i en plott på ett mycket liknande sätt att lägga till poäng, förutom att du använder funktionen linjer () för att uppnå detta. Men använd först lite R magi för att skapa en trendlinje genom data, kallad en regressionsmodell. Du använder lm () -funktionen för att uppskatta en linjär ...

Hur man lägger till en andra dimension i R-dummies

Hur man lägger till en andra dimension i R-dummies

Förutom vektorer kan R representera matriser som ett objekt du arbetar och beräknar med. Faktum är att R verkligen lyser när det gäller matrisberäkningar och -operationer. Vektorer är nära relaterade till en större klass av objekt, arrays. Arrayer har två mycket viktiga egenskaper: De innehåller bara en enda typ av värde. De har ...