Acasă Finanțe personale Care se ocupă de complexitatea algoritmului - dummy

Care se ocupă de complexitatea algoritmului - dummy

Video: EDI 0 - partea a cincea - Despre supervizor si algoritmi - prezentarea algoritmului general 2024

Video: EDI 0 - partea a cincea - Despre supervizor si algoritmi - prezentarea algoritmului general 2024
Anonim

O parte din algoritmi pentru chestii Cheat Sheet

Știți deja că algoritmii sunt complexe. Cu toate acestea, trebuie să știți cât de complex este un algoritm deoarece este mai complexă, cu atât mai mult este nevoie să îl executați. Următorul tabel vă ajută să înțelegeți diferitele niveluri de complexitate prezentate în ordinea timpului de rulare (de la cel mai rapid la cel mai lent).

Complexitate Descriere
Complexitate constantă O (1) Oferă un timp de execuție neobișnuit, indiferent de cantitatea de intrare pe care o furnizați. Fiecare intrare necesită o singură unitate de timp de execuție.
Complexitatea logaritmică O (log n) Numărul de operații crește cu o viteză mai mică decât intrarea, făcând algoritmul mai puțin eficient cu intrări mici și mai eficient cu cele mai mari. Un algoritm tipic din această clasă este căutarea binară.
Complexitatea liniară O (n) Operațiile cresc cu intrarea într-un raport 1: 1. Un algoritm tipic este iterația, când scanați o dată intrarea și aplicați o operație fiecărui element al acesteia.
Complexitatea liniaritmică O (n log n) Complexitatea este o combinație între complexitatea logaritmică și liniară. Este tipic unii algoritmi inteligenți folosiți pentru a comanda date, cum ar fi Mergesortsort, Heapsort și Quicksort.
Complexitatea patratică O (n 2 ) Operațiile cresc ca un pătrat al numărului de intrări. Când aveți o iterație în interiorul unei alte iterații (numite iterații imbricate în informatică), aveți complexitate patratică. De exemplu, aveți o listă de nume și, pentru a găsi cele mai similare, comparați fiecare nume cu toate celelalte nume. Alți algoritmi de ordonare mai puțin eficienți prezintă o astfel de complexitate: sortarea bulei, sortarea selecției și sortarea inserției. Acest nivel de complexitate înseamnă că algoritmii dvs. pot funcționa cu ore sau chiar zile înainte de a ajunge la o soluție.
Complexitatea cubică O (n 3 ) Operațiile cresc chiar mai repede decât complexitatea cuadratoare, deoarece acum aveți mai multe iterații imbricate. Atunci când un algoritm are această ordine de complexitate și trebuie să procesați o cantitate modestă de date (100, 000 de elemente), algoritmul dvs. poate rula de ani de zile. Atunci când aveți o serie de operații care reprezintă o putere a intrării, este comun să se facă referire la algoritm ca fiind executat în timp polinomial.
Complexitatea exponențială O (2 n ) Algoritmul ia de două ori numărul operațiilor anterioare pentru fiecare element adăugat nou. Când un algoritm are această complexitate, chiar și problemele mici pot dura pentru totdeauna. Mulți algoritmi care efectuează căutări exhaustive au complexitate exponențială. Cu toate acestea, exemplul clasic pentru acest nivel de complexitate este calculul numerelor Fibonacci.
Complexitatea factorilor O (n!) Acest algoritm prezintă un adevărat coșmar de complexitate datorită numărului mare de combinații posibile dintre elemente. Doar imaginați-vă: Dacă intrarea dvs. este de 100 de obiecte și o operațiune pe computer durează 10 -6 secunde (o viteză rezonabilă pentru fiecare calculator de astăzi), veți avea nevoie de aproximativ 10 140 pentru a finaliza cu succes sarcina (un timp imposibil deoarece vârsta universului este estimată la 10 14 ani). O problemă faimoasă a complexității factoriale este problema vânzătorilor care călătoresc, în care un vânzător trebuie să găsească cel mai scurt traseu pentru a vizita multe orașe și pentru a reveni la orașul de plecare.
Care se ocupă de complexitatea algoritmului - dummy

Alegerea editorilor

Administrator de rețea: Zone de căutare inversă - dummies

Administrator de rețea: Zone de căutare inversă - dummies

Interogări DNS obișnuite sunt interogări de căutare înainte corespunde unui nume de domeniu complet calificat. O căutare inversă este opusul unei căutări forward: returnează numele de domeniu complet calificat al unei gazde pe baza adresei sale IP. Căutările inverse sunt posibile din cauza unui domeniu special numit ...

Rețea Elemente de bază: Clienți și servere - manechine

Rețea Elemente de bază: Clienți și servere - manechine

Computerul de rețea care conține hard disk-urile, imprimantele și alte resurse care sunt partajate cu alte calculatoare de rețea se numește un server. Acest termen vine în repetate rânduri, deci trebuie să-l amintiți. Scrie-o pe spatele mâinii tale stângi. Orice computer care nu este un server este numit client. Aveți ...

Retea Bazele: Poduri - dummies

Retea Bazele: Poduri - dummies

O punte este un dispozitiv care conecteaza doua retele astfel incat sa actioneze ca si cum ar fi o rețea. Podurile sunt utilizate pentru a împărți o rețea mare în două rețele mai mici din motive de performanță. Vă puteți gândi la un pod ca pe un repetor inteligent. Repetoarele ascultă semnale care coboară pe un cablu de rețea, amplifică ...

Alegerea editorilor

ÎMprumuta și tweak idei de la alte comunități online - dummies

ÎMprumuta și tweak idei de la alte comunități online - dummies

, Mai degrabă decât să ia ideile altcuiva complet pentru dvs. comunitate online, încercați să riffați pe aceeași idee, dar nu atât de mult încât este evident că nu sunteți creierul din spatele brainstorming-ului. Idei sunt acolo pentru a lua, dar nu ar fi mai degrabă văzute ca cineva inovatoare, nu cineva care scours pe web ...

Branding Blogul tău

Branding Blogul tău

Branding blog-ul tău merge mult spre a face dacă este ușor de recunoscut pentru cititorii tăi. Când vedeți un punct roșu în interiorul unui cerc roșu, ce magazin vine în minte? Ce zici de acele arcuri de aur? Un nume de marcă apare în minte atunci când vedeți simbolul swoosh? La fel ca magazinele populare, restaurantele și încălțămintea ...

Construiți un Blog Mama care este Sellable - dummies

Construiți un Blog Mama care este Sellable - dummies

Dacă obiectivul pe termen lung este de a vinde blogul dvs. ar trebui să o construiască cu acest scop în minte. Evitați asocierea prea intensă a blogului cu marca dvs. personală. Un blog care poate fi valoros cu orice scriitor la cârma trebuie să îndeplinească majoritatea, dacă nu toate, următoarele criterii: Blogul este concentrat ...

Alegerea editorilor

Cum să creați o nouă campanie de anunțuri LinkedIn - dummies

Cum să creați o nouă campanie de anunțuri LinkedIn - dummies

LinkedIn oferă servicii de publicitate pentru afacerea dvs. Dacă vă decideți să utilizați LinkedIn ca instrument de marketing, va trebui doar să obțineți o nouă campanie de anunțuri în lucrări. Când sunteți gata să începeți o nouă campanie, urmați acești pași:

Opțiuni de filtrare pentru anunțul dvs. LinkedIn - manechine

Opțiuni de filtrare pentru anunțul dvs. LinkedIn - manechine

Ce opțiuni de filtrare aveți pentru anunțul dvs. LinkedIn? Alte rețele de publicitate vă permit să filtrați publicul vizat de câteva atribute cunoscute ale persoanei care vă va vedea anunțul, sexul și locația membrilor din public. LinkedIn vă permite să faceți un pas mai departe permițându-vă ...

Oferind și primind viziuni pe LinkedIn - manechine

Oferind și primind viziuni pe LinkedIn - manechine

Deși mulți oameni cred că "Nu este ceea ce știi, știi, "care este unul dintre principalele motive pentru care LinkedIn este atât de valoros, mulți oameni (recrutorii, angajații, directorii executivi, investitorii și altele) sunt foarte interesați de ceea ce știi. În mod logic, oamenii care vă cunosc cel mai bine sunt oamenii din rețeaua dvs., care ...