Web - Amazon

We provide Linux to the World


We support WINRAR [What is this] - [Download .exe file(s) for Windows]

CLASSICISTRANIERI HOME PAGE - YOUTUBE CHANNEL
SITEMAP
Audiobooks by Valerio Di Stefano: Single Download - Complete Download [TAR] [WIM] [ZIP] [RAR] - Alphabetical Download  [TAR] [WIM] [ZIP] [RAR] - Download Instructions

Make a donation: IBAN: IT36M0708677020000000008016 - BIC/SWIFT:  ICRAITRRU60 - VALERIO DI STEFANO or
Privacy Policy Cookie Policy Terms and Conditions
Wyszukiwanie binarne - Wikipedia, wolna encyklopedia

Wyszukiwanie binarne

Z Wikipedii

Wyszukiwanie binarne jest algorytmem opierającym się na metodzie dziel i zwyciężaj, który w czasie logarytmicznym stwierdza, czy szukany element znajduje się w uporządkowanej tablicy i jeśli się znajduje, podaje jego indeks.

[edytuj] Zasada działania algorytmu

Uporządkowaną tablicę dzielimy na coraz mniejsze kawałki (przedziały) do momentu, gdy znajdziemy szukany element bądź przedział będzie zerowej długości (brak elementu). Rozpoczynamy od pełnej tablicy, czyli lewy koniec przedziału ustawiamy na początek tablicy a prawy na koniec. Następnie "celujemy" w środek przedziału i odczytujemy wartość. Jeśli jest równa szukanemu elementowi to koniec, znaleźliśmy element, wpp. są możliwe dwa przypadki. Jeśli odczytana wartość jest większa od szukanej oraz tablica jest uporządkowana niemalejąco (odpowiednio malejąco), prawy (lewy) koniec przedziału ustawiamy na odczytaną wartość. W drugim przypadku - odczytana wartość mniejsza - postępujemy analogicznie, czyli: lewym (prawym) końcem przedziału staje się "środkowy" element. Algorytm wykonujemy tak długo, aż znajdziemy szukany element bądź lewy koniec "znajdzie się" za prawym końcem.

[edytuj] Przykładowy kod

Kod wyszukiwania binarnego w C++, dla tablicy uporządkowanej niemalejąco (→ sortowanie).

int szukaj(int *tab, int n, int x) {
/* parametry:
 * tab - wskaźnik na tablicę elementów
 * n   - liczba elementów w tablicy
 * x   - szukany element
 * zwracana wartość:
 * indeks elementu - jeśli znajduje się w tablicy
 * w przeciwnym wypadku zwraca -1
 */
  int pocz = -1, kon = n , srod = 0;    
 
  while (kon > pocz + 1) {
    srod = ( pocz + kon ) / 2;
    if (tab[srod] == x)  
      return(srod);
    else {
    if (tab[srod] < x)
      pocz = srod;
    else
      kon = srod;
    }
  }  
  return(-1);    
}

[edytuj] Zobacz też

Our "Network":

Project Gutenberg
https://gutenberg.classicistranieri.com

Encyclopaedia Britannica 1911
https://encyclopaediabritannica.classicistranieri.com

Librivox Audiobooks
https://librivox.classicistranieri.com

Linux Distributions
https://old.classicistranieri.com

Magnatune (MP3 Music)
https://magnatune.classicistranieri.com

Static Wikipedia (June 2008)
https://wikipedia.classicistranieri.com

Static Wikipedia (March 2008)
https://wikipedia2007.classicistranieri.com/mar2008/

Static Wikipedia (2007)
https://wikipedia2007.classicistranieri.com

Static Wikipedia (2006)
https://wikipedia2006.classicistranieri.com

Liber Liber
https://liberliber.classicistranieri.com

ZIM Files for Kiwix
https://zim.classicistranieri.com


Other Websites:

Bach - Goldberg Variations
https://www.goldbergvariations.org

Lazarillo de Tormes
https://www.lazarillodetormes.org

Madame Bovary
https://www.madamebovary.org

Il Fu Mattia Pascal
https://www.mattiapascal.it

The Voice in the Desert
https://www.thevoiceinthedesert.org

Confessione d'un amore fascista
https://www.amorefascista.it

Malinverno
https://www.malinverno.org

Debito formativo
https://www.debitoformativo.it

Adina Spire
https://www.adinaspire.com