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

Hur man lägger till text i en sätter () Funktion i C Programmering

Hur man lägger till text i en sätter () Funktion i C Programmering

När du behöver visa en annan textrad, använd C-programmeringsfärdigheterna för att skapa en annan puts () -funktion i källkoden, som visas i Visa två textlinjer. VISA TILL TEXTFINER # inkludera int main () {sätter ("Hickory, Dickory, Dock,"); sätter ("musen sprang klockan."); returnera (0);} Den andra ...

Förklarar variabler i C-dummies

Förklarar variabler i C-dummies

Variabler är det som gör dina program zooma. Programmering kan bara inte bli gjort utan dem. Så om du inte har introducerats till variabler än, här går du. Valerie Variable är en numerisk variabel. Hon älskar att hålla nummer - vilket nummer som helst; det spelar ingen roll. När hon ser ett lika tecken tar hon ett värde och ...

Redaktörens val

Gör rädsla för din vän - dummies

Gör rädsla för din vän - dummies

Rädsla är lika verklig som mod. Även om värdet av rädsla inte är lika uppenbart som modets värde, har det dess fördelar. Rädsla är din instinkt som säger att du är obehaglig - även om situationen inte kommer att skada dig. Alla har haft den känslan när man hellre drar locket ...

Hur man ökar din självmedvetenhet - dummies

Hur man ökar din självmedvetenhet - dummies

Du kommer att vara med dig själv under en livstid. Ingenting kommer att förändra det faktum. Att lära känna, som att lyssna på och uppskatta själv är avgörande för din sanity. Kanske kommer du till att älska, acceptera och omfamna alla du är, är svår för dig att föreställa dig just nu, men du kan göra ...

Hur man ökar din mentala flexibilitet - dummies

Hur man ökar din mentala flexibilitet - dummies

ÄR flexibel i arbete och relationer är ett tecken på en högpresterande. Medan perfektionister är styva och obehagliga i sitt arbete och hur de interagerar med andra, är högpresterande mer öppna och tillmötesgående. Att vara mer flexibel på jobbet gav Ralph aldrig förslag under brainstorming vid gruppmöten. Han kände att hans lag ...

Redaktörens val

Nätverksadministration: Linux-installation och virtuella konsoler - dummies

Nätverksadministration: Linux-installation och virtuella konsoler - dummies

Linux är i sig ett kommandoradsorienterat operativsystem. Grafiska användargränssnitt - inklusive installationsprogrammets GUI - tillhandahålls av en valfri komponent som heter X Window System. Men medan du arbetar med det grafiska användargränssnittet för installationsprogrammet, håller Linux flera ytterligare kommandorads-konsoler öppna. Normalt behöver du inte ...

Nätverksadministration: Linux-loggning, logg och systemavstängning - dummies

Nätverksadministration: Linux-loggning, logg och systemavstängning - dummies

Alla användare som åtkomst ett Linux-system, lokalt eller över ett nätverk, måste verifieras av ett giltigt användarkonto på systemet. I det följande får du veta hur du loggar in och ut på ett Linux-system och hur du stänger av systemet. Logga in När Linux startar upp visas det ...

Nätverksadministration: Licensserver - Dummies

Nätverksadministration: Licensserver - Dummies

I vissa program kan du köpa nätverkslicenser som gör att du kan installera programvaran på många datorer som du vill, men reglera antalet personer som kan använda programvaran vid en viss tidpunkt. För att styra hur många som använder programvaran, är en särskild licensserver inrättad. När en användare börjar ...