Hem Personliga finanser Som handlar om algoritmkomplexitet - dummies <[SET:descriptionsv]Som du redan vet att algoritmer är komplexa.

Som handlar om algoritmkomplexitet - dummies <[SET:descriptionsv]Som du redan vet att algoritmer är komplexa.

Video: Lag Syd gör upp i immunitetstävling som handlar om uthållighet – Robinson (TV4) 2024

Video: Lag Syd gör upp i immunitetstävling som handlar om uthållighet – Robinson (TV4) 2024
Anonim

En del av Algorithms For Dummies Cheat Sheet

Du vet redan att algoritmer är komplexa. Men du behöver veta hur komplex en algoritm är för att ju mer komplexa är, desto längre tid tar det att springa. Följande tabell hjälper dig att förstå de olika nivåerna av komplexitet som presenteras i ordning av körtid (från snabbast till långsammaste).

Komplexitet Beskrivning
Konstant komplexitet O (1) Ger en ojämn exekveringstid, oavsett hur mycket input du tillhandahåller. Varje ingång kräver en enda enhet för körningstid.
Logaritmisk komplexitet O (log n) Antalet operationer växer långsammare än ingången, vilket gör algoritmen mindre effektiv med små ingångar och effektivare med större. En typisk algoritm för denna klass är binärsökningen.
Linjär komplexitet O (n) Verksamheten växer med ingången i ett 1: 1-förhållande. En typisk algoritm är iteration, när du skannar in en gång och tillämpar en operation på varje del av den.
Linearitmisk komplexitet O (n log n) Komplexitet är en blandning mellan logaritmisk och linjär komplexitet. Det är typiskt för några smarta algoritmer som används för att beställa data, till exempel Mergesortsort, Heapsort och Quicksort.
Kvadratisk komplexitet O (n 2 ) Verksamheten växer som en kvadrat av antalet ingångar. När du har en iteration inom en annan iteration (kallad nestade iterationer i datavetenskap), har du kvadratisk komplexitet. Du har till exempel en lista över namn och för att hitta de mest liknande, jämför du varje namn mot alla andra namn. Några mindre effektiva beställningsalgoritmer presenterar sådan komplexitet: bubbelsort, urvalssort och insertionssort. Denna nivå av komplexitet innebär att dina algoritmer kan springa i timmar eller till och med dagar innan de når en lösning.
Kubisk komplexitet O (n 3 ) Operationerna växer ännu snabbare än kvadratisk komplexitet, för nu har du flera nestade iterationer. När en algoritm har denna ordning med komplexitet och du behöver bearbeta en blygsam mängd data (100 000 element), kan din algoritm löpa i flera år. När du har ett antal operationer som är en kraft för ingången, är det vanligt att referera till algoritmen som löpande i polynomisk tid.
Exponentiell komplexitet O (2 n ) Algoritmen tar dubbelt så många tidigare operationer för varje nytt element som läggs till. När en algoritm har denna komplexitet kan även små problem ta evigt. Många algoritmer som gör uttömmande sökningar har exponentiell komplexitet. Det klassiska exemplet för denna nivå av komplexitet är emellertid beräkningen av Fibonacci-nummer.
Faktisk komplexitet O (n!) Denna algoritm presenterar en riktig mardröm av komplexitet på grund av det stora antalet möjliga kombinationer mellan elementen. Tänk dig att: Om din ingång är 100 objekt och en operation på din dator tar 10 -6 sekunder (en rimlig hastighet för varje dator nuförtiden) behöver du cirka 10 140 år för att slutföra uppgiften framgångsrikt (en omöjlig tid eftersom universumets ålder beräknas vara 10 14 år). Ett känt problem med problemkomplexiteten är det resande säljareproblemet, där en säljare måste hitta den kortaste vägen för att besöka många städer och komma tillbaka till startstaden.
Som handlar om algoritmkomplexitet - dummies <[SET:descriptionsv]Som du redan vet att algoritmer är komplexa.

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 ...