Rodina používa laptop.
Kredit za obrázok: altrendo images/Stockbyte/Getty Images
Vyhľadávacie algoritmy tvoria dôležitú súčasť mnohých programov. Niektoré vyhľadávania zahŕňajú hľadanie záznamu v databáze, napríklad vyhľadávanie vášho záznamu v databáze IRS. Iné vyhľadávacie algoritmy prechádzajú virtuálnym priestorom, napríklad tie, ktoré hľadajú najlepšie šachové ťahy. Aj keď si programátori môžu vybrať z mnohých typov vyhľadávania, vyberú si algoritmus, ktorý najlepšie zodpovedá veľkosti a štruktúre databázy, aby poskytli užívateľsky prívetivú skúsenosť.
Lineárne vyhľadávanie
Lineárne vyhľadávanie je algoritmus voľby pre krátke zoznamy, pretože je jednoduchý a vyžaduje minimálny kód na implementáciu. Algoritmus lineárneho vyhľadávania sa pozrie na prvú položku zoznamu, aby zistil, či ju hľadáte, a ak áno, ste hotový. Ak nie, pozrie sa na ďalšiu položku a ďalej na každú položku v zozname.
Video dňa
Binárne vyhľadávanie
Binárne vyhľadávanie je populárny algoritmus pre veľké databázy so záznamami zoradenými podľa číselného kľúča. Príklady kandidátov zahŕňajú databázu IRS kľúčovanú číslom sociálneho poistenia a záznamy DMV kľúčované číslami vodičských preukazov. Algoritmus začína v strede databázy -- ak je vaše cieľové číslo väčšie ako stredné číslo, vyhľadávanie bude pokračovať v hornej polovici databázy. Ak je vaše cieľové číslo menšie ako stredné číslo, vyhľadávanie bude pokračovať v spodnej polovici databázy. Tento proces neustále opakuje, pričom zakaždým rozdelí databázu na polovicu, kým nenájde záznam. Toto vyhľadávanie je komplikovanejšie ako lineárne vyhľadávanie, ale pre veľké databázy je oveľa rýchlejšie ako lineárne vyhľadávanie.
Tree Search
Stromové vyhľadávanie funguje iba vtedy, ak údaje zapadajú do stromovej štruktúry. Databáza začína v koreňovom adresári, ktorý prechádza na niekoľko položiek, z ktorých každá prechádza na niekoľko ďalších položiek a tak ďalej, kým nemáte strom. Jedným z príkladov je šachová hra. Aktuálna pozícia dosky je koreňová. Zákonné ťahy z tejto pozície predstavujú jeden krok po strome a tak ďalej, kým hráč nenájde pozíciu na šachovnici, ktorá ho ponecháva v najlepšej pozícii.
Genetický algoritmus
Hľadanie genetického algoritmu je jednou z techník umelej inteligencie. Hľadá „optimálne riešenie“ vyjadrené ako reťazec údajov – napríklad zoznam vnútorných rozmerov prúdového motora, ktorý poskytuje maximálny ťah. Hľadanie začína náhodnou populáciou reťazcov a testuje každý z nich, pričom si ponechá tie najlepšie a rozmnožuje ich, aby získali ďalšiu generáciu. Program tento proces neustále opakuje, kým nedosiahne optimálne riešenie.