DAA - Pencarian Biner

Pada bab ini, kita akan membahas algoritma lain berdasarkan metode divide and conquer.

Pernyataan masalah

Pencarian biner dapat dilakukan pada array yang diurutkan. Dalam pendekatan ini, indeks suatu elemenxditentukan jika elemen tersebut termasuk dalam daftar elemen. Jika array tidak diurutkan, pencarian linier digunakan untuk menentukan posisinya.

Larutan

Dalam algoritma ini, kami ingin mencari elemen apakah x milik satu set angka yang disimpan dalam array numbers[]. Dimanal dan r mewakili indeks kiri dan kanan dari sub-larik tempat operasi pencarian harus dilakukan.

Algorithm: Binary-Search(numbers[], x, l, r)
if l = r then  
   return l  
else 
   m := ⌊(l + r) / 2⌋ 
   if x ≤ numbers[m]  then 
      return Binary-Search(numbers[], x, l, m) 
   else 
      return Binary-Search(numbers[], x, m+1, r)

Analisis

Pencarian linier berjalan masuk O(n)waktu. Sedangkan pencarian biner menghasilkan hasil dalamO(log n) waktu

Membiarkan T(n) menjadi jumlah perbandingan dalam kasus terburuk dalam larik n elemen.

Karenanya,

$$ T (n) = \ mulai {kasus} 0 & jika \: n = 1 \\ T (\ frac {n} {2}) + 1 & sebaliknya \ end {kasus} $$

Menggunakan relasi pengulangan ini $ T (n) = log \: n $.

Oleh karena itu, pencarian biner menggunakan $ O (log \: n) $ waktu.

Contoh

Dalam contoh ini, kita akan mencari elemen 63.