
İkili Arama Algoritması Açıklaması
İkili Arama, sıralı bir dizideki hedef değeri arama aralığını sürekli olarak ikiye bölerek bulan verimli bir arama algoritmasıdır. Elemanları tek tek kontrol etmek yerine, hedefi ortadaki elemanla karşılaştırır ve aramaya sol yarıda mı yoksa sağ yarıda mı devam edeceğine karar verir.
İkili Arama, büyük sıralı veri kümeleri için Doğrusal Arama'dan çok daha hızlıdır. Zaman karmaşıklığı O(log n)'dir, bu da giriş boyutu büyüdüğünde bile gereken kontrol sayısının çok yavaş arttığı anlamına gelir.
Giriş
Arama, programlamadaki en yaygın işlemlerden biridir. Geliştiriciler genellikle bir veri koleksiyonu içinde belirli bir sayı, kullanıcı, ürün, kayıt, kimlik, tarih veya değer bulmaya ihtiyaç duyarlar.
Doğrusal Arama, elemanları tek tek kontrol ettiği için en basit arama yöntemidir. Ancak, veri büyük olduğunda her elemanı kontrol etmek yavaşlayabilir. İkili Arama bu sorunu önemli bir koşul kullanarak çözer: verilerin sıralı olması gerekir.
Dizi sıralı olduğunda, İkili Arama her karşılaştırmadan sonra kalan elemanların yarısını göz ardı edebilir. Bu, verimli arama, logaritmik zaman karmaşıklığı ve böl-yönet (divide-and-conquer) düşüncesini öğrenmek için en önemli algoritmalardan biri yapar.
İkili Arama Nedir?
İkili Arama, sıralı bir dizide hedef bir değeri bulmak için kullanılan bir arama algoritmasıdır. Hedef değeri, mevcut arama aralığının ortadaki elemanıyla karşılaştırarak çalışır.
Ortadaki eleman hedefe eşitse, arama tamamlanır. Hedef, ortadaki elemandan küçükse, algoritma sol yarıda aramaya devam eder. Hedef, ortadaki elemandan büyükse, algoritma sağ yarıda aramaya devam eder.
Ana fikir basittir:
Tüm sıralı diziyle başlayın.
Ortadaki elemanı bulun.
Ortadaki elemanı hedefle karşılaştırın.
Hedef bulunursa, dizinini döndürün.
Hedef daha küçükse, sol yarıda arama yapın.
Hedef daha büyükse, sağ yarıda arama yapın.
Hedef bulunana veya arama aralığı boş olana kadar tekrarlayın.
İkili Arama, her adımda arama alanını ikiye böldüğü için "ikili" olarak adlandırılır.
En Önemli Gereklilik
İkili Arama sadece dizi sıralı olduğunda doğru çalışır.
Örneğin, bu dizi sıralıdır:
[2, 4, 6, 8, 10, 12, 14]İkili Arama bu dizi üzerinde çalışabilir çünkü tüm değerler artan düzende sıralanmıştır.
Ama bu dizi sıralı değildir:
[8, 2, 14, 4, 10, 6, 12]İkili Arama bu dizi üzerinde doğrudan kullanılmamalıdır çünkü algoritma, daha küçük değerlerin solda, daha büyük değerlerin sağda olduğunu bilmeye bağlıdır.
Veri sıralı değilse, geliştiriciler önce onu sıralamalı veya Doğrusal Arama gibi başka bir arama yöntemi kullanmalıdır.
İkili Arama Neden Önemli
İkili Arama önemlidir çünkü basit bir fikrin performansı nasıl önemli ölçüde artırabileceğini gösterir. Her değeri kontrol etmek yerine, algoritma her karşılaştırmadan sonra kalan arama alanının yarısını eler.
Bu, çok büyük bir dizinin bile yalnızca az sayıda kontrolle aranabileceği anlamına gelir.
Örneğin:
16 elemanlı bir dizide, İkili Arama en fazla yaklaşık 4 kontrole ihtiyaç duyar.
1.024 elemanlı bir dizide, en fazla yaklaşık 10 kontrole ihtiyaç duyar.
1.000.000 elemanlı bir dizide, yaklaşık 20 kontrole ihtiyaç duyar.
Bu verimlilik, İkili Arama'nın bilgisayar bilimlerinde temel bir algoritma olmasının nedenidir.
İkili Arama Nasıl Çalışır
İkili Arama, iki sınırı takip eder: sol sınır ve sağ sınır. Bu sınırlar mevcut arama aralığını tanımlar.
Her adımda, algoritma ortadaki dizini hesaplar:
middle = left + (right - left) / 2Ardından ortadaki değeri hedef değerle karşılaştırır.
Ortadaki değer çok küçükse, hedefin sağ tarafta olması gerekir. Ortadaki değer çok büyükse, hedefin sol tarafta olması gerekir. Ortadaki değer hedefle eşleşirse, algoritma ortadaki dizini döndürür.
Bu işlem, arama aralığı boş olana kadar devam eder.
Manuel Çalıştırma Örneği
Aşağıdaki sıralı dizide hedef değer 14'ü manuel olarak arayalım:
[2, 4, 6, 8, 10, 12, 14, 16, 18]Hedef değer şudur:
Target = 14Dizi dizinleri şunlardır:
Index: 0 1 2 3 4 5 6 7 8
Value: 2 4 6 8 10 12 14 16 18Adım 1: Başlangıç Sınırlarını Ayarla
Başlangıçta, sol sınır ilk dizin ve sağ sınır son dizindir.
left = 0
right = 8Şimdi ortadaki dizini hesaplıyoruz:
middle = 0 + (8 - 0) / 2 = 4Ortadaki değer şudur:
array[4] = 10Ortadaki değeri hedefle karşılaştırın:
10 == 14 ? No
10 < 14 ? Yes10, 14'ten küçük olduğu için hedef sağ yarıda olmalıdır.
Bu yüzden sol sınırı taşıyoruz:
left = middle + 1 = 5Adım 2: Sağ Yarıyı Ara
Mevcut arama aralığı şimdi şudur:
[12, 14, 16, 18]Sınırlar şunlardır:
left = 5
right = 8Ortadaki dizini hesaplayın:
middle = 5 + (8 - 5) / 2 = 6Ortadaki değer şudur:
array[6] = 14Ortadaki değeri hedefle karşılaştırın:
14 == 14 ? YesHedef 6. dizinde bulundu.
Arama Sonucu
Target 14 found at index 6İkili Arama hedefi sadece iki kontrolde buldu. Doğrusal Arama bu örnekte 14'e ulaşmadan önce yedi elemanı kontrol ederdi.
Değer Bulunmadığında Manuel Çalıştırma
Şimdi aynı sıralı dizide hedef değer 15'i arayalım:
[2, 4, 6, 8, 10, 12, 14, 16, 18]Hedef değer şudur:
Target = 15Adım 1
Başlangıç sınırları:
left = 0
right = 8Ortadaki dizin:
middle = 4Ortadaki değer:
array[4] = 1010, 15'ten küçük olduğu için sağ yarıyı ara:
left = 5
right = 8Adım 2
Mevcut arama aralığı:
[12, 14, 16, 18]Ortadaki dizin:
middle = 6Ortadaki değer:
array[6] = 1414, 15'ten küçük olduğu için sağ yarıyı ara:
left = 7
right = 8Adım 3
Mevcut arama aralığı:
[16, 18]Ortadaki dizin:
middle = 7Ortadaki değer:
array[7] = 1616, 15'ten büyük olduğu için sol yarıyı ara:
left = 7
right = 6Şimdi sol sınır, sağ sınırdan büyük. Bu, arama aralığının boş olduğu anlamına gelir.
Arama Sonucu
Target 15 was not foundAlgoritma durur çünkü aranacak dizinin kalan bir kısmı yoktur.
İkili Arama Algoritması Adımları
İteratif İkili Arama algoritması şu adımları takip eder:
Sıralı bir dizi ve bir hedef değer alın.
leftdeğerini 0 olarak ayarlayın.rightdeğerini dizinin son dizini olarak ayarlayın.leftdeğerirightdeğerinden küçük veya eşit olduğu sürece, ortadaki dizini hesaplayın.Ortadaki değer hedefe eşitse, ortadaki dizini döndürün.
Ortadaki değer hedeften küçükse,
leftdeğerinimiddle + 1değerine taşıyın.Ortadaki değer hedeften büyükse,
rightdeğerinimiddle - 1değerine taşıyın.Döngü biterse, hedef bulunamadığı için -1 döndürün.
Bu versiyon özyineleme gerektirmez ve pratik kodda kullanılması genellikle en kolay versiyondur.
Sözde Kod
binarySearch(array, target):
left = 0
right = length(array) - 1
while left <= right:
middle = left + (right - left) / 2
if array[middle] == target:
return middle
if array[middle] < target:
left = middle + 1
else:
right = middle - 1
return -1Fonksiyon, hedef değer mevcutsa onun dizinini döndürür. Hedef mevcut değilse, -1 döndürür.
PHP'de İkili Arama Örneği
İkili Arama'nın temiz bir iteratif PHP uygulaması aşağıdadır:
<?php
function binarySearch(array $numbers, int $target): int
{
$left = 0;
$right = count($numbers) - 1;
while ($left <= $right) {
$middle = $left + intdiv($right - $left, 2);
if ($numbers[$middle] === $target) {
return $middle;
}
if ($numbers[$middle] < $target) {
$left = $middle + 1;
} else {
$right = $middle - 1;
}
}
return -1;
}
$numbers = [2, 4, 6, 8, 10, 12, 14, 16, 18];
echo binarySearch($numbers, 14);Çıktı şöyle olacaktır:
6Hedef değer 14, 6. dizinde bulunduğundan, fonksiyon 6 döndürür.
Değer Bulunmadığında PHP'de İkili Arama
Mevcut olmayan bir değeri ararsak:
<?php
$numbers = [2, 4, 6, 8, 10, 12, 14, 16, 18];
echo binarySearch($numbers, 15);Çıktı şöyle olacaktır:
-115 değeri dizide mevcut değil, bu yüzden fonksiyon -1 döndürür.
JavaScript'te İkili Arama Örneği
Aynı algoritmanın JavaScript'te uygulanmış hali aşağıdadır:
function binarySearch(numbers, target) {
let left = 0;
let right = numbers.length - 1;
while (left <= right) {
const middle = left + Math.floor((right - left) / 2);
if (numbers[middle] === target) {
return middle;
}
if (numbers[middle] < target) {
left = middle + 1;
} else {
right = middle - 1;
}
}
return -1;
}
const numbers = [2, 4, 6, 8, 10, 12, 14, 16, 18];
console.log(binarySearch(numbers, 14));Çıktı şöyle olacaktır:
6JavaScript versiyonu PHP versiyonuyla aynı mantığı takip eder. Ortadaki değeri tekrar tekrar kontrol eder ve arama aralığının yarısını kaldırır.
Özyinelemeli İkili Arama
İkili Arama özyinelemeli olarak da uygulanabilir. Özyinelemeli versiyonda, fonksiyon daha küçük bir arama aralığıyla kendini çağırır.
Özyinelemeli fikir şudur:
Aralık boşsa, -1 döndürün.
Ortadaki elemanı kontrol edin.
Hedef bulunursa, ortadaki dizini döndürün.
Hedef daha küçükse, özyinelemeli olarak sol yarıyı arayın.
Hedef daha büyükse, özyinelemeli olarak sağ yarıyı arayın.
Özyinelemeli versiyon zariftir, ancak iteratif versiyon genellikle daha hafıza verimlidir çünkü özyinelemeli çağrı yığını çerçeveleri oluşturmaz.
PHP'de Özyinelemeli İkili Arama
<?php
function recursiveBinarySearch(array $numbers, int $target, int $left, int $right): int
{
if ($left > $right) {
return -1;
}
$middle = $left + intdiv($right - $left, 2);
if ($numbers[$middle] === $target) {
return $middle;
}
if ($numbers[$middle] > $target) {
return recursiveBinarySearch($numbers, $target, $left, $middle - 1);
}
return recursiveBinarySearch($numbers, $target, $middle + 1, $right);
}
$numbers = [2, 4, 6, 8, 10, 12, 14, 16, 18];
echo recursiveBinarySearch($numbers, 14, 0, count($numbers) - 1);Çıktı şöyle olacaktır:
6Özyinelemeli fonksiyon, hedefi bulana veya aralık boş olana kadar arama aralığını küçültmeye devam eder.
JavaScript'te Özyinelemeli İkili Arama
function recursiveBinarySearch(numbers, target, left = 0, right = numbers.length - 1) {
if (left > right) {
return -1;
}
const middle = left + Math.floor((right - left) / 2);
if (numbers[middle] === target) {
return middle;
}
if (numbers[middle] > target) {
return recursiveBinarySearch(numbers, target, left, middle - 1);
}
return recursiveBinarySearch(numbers, target, middle + 1, right);
}
const numbers = [2, 4, 6, 8, 10, 12, 14, 16, 18];
console.log(recursiveBinarySearch(numbers, 14));Çıktı şöyle olacaktır:
6Bu versiyon özyinelemeyi öğrenmek için faydalıdır, ancak üretim kodunda genellikle iteratif versiyon tercih edilir.
Ortayı Neden Bu Şekilde Hesaplarız
Ortadaki dizinin şöyle hesaplandığını görebilirsiniz:
middle = (left + right) / 2Bu, küçük sayılar için çalışır, ancak bazı programlama dillerinde, dizinler çok büyük olduğunda left ve right doğrudan toplamak tamsayı taşmasına neden olabilir.
Daha güvenli bir formül şudur:
middle = left + (right - left) / 2Bu, potansiyel olarak büyük iki dizini bir araya eklemeyi önler. PHP ve JavaScript örneklerinde bu daha güvenli stili kullandık.
İkili Arama'nın Zaman Karmaşıklığı
Zaman karmaşıklığı, bir algoritmanın çalışma süresinin giriş boyutu arttıkça nasıl büyüdüğünü açıklar. İkili Arama verimlidir çünkü her adım arama aralığını ikiye böler.
İkili Arama'nın zaman karmaşıklığı şöyledir:
En iyi durum: O(1)
Ortalama durum: O(log n)
En kötü durum: O(log n)
Burada n, sıralı dizideki eleman sayısıdır.
En İyi Durum Zaman Karmaşıklığı: O(1)
En iyi durum, hedef değerin ilk kontrolde ortadaki konumda bulunmasıyla gerçekleşir.
Array: [2, 4, 6, 8, 10]
Target: 6Ortadaki değer 6'dır, bu yüzden algoritma hedefi hemen bulur.
Bu nedenle, en iyi durum zaman karmaşıklığı şudur:
O(1)Bu, sabit zaman anlamına gelir çünkü sadece bir karşılaştırma gereklidir.
Ortalama Durum Zaman Karmaşıklığı: O(log n)
Ortalama durum, hedefin hemen bulunmaması, ancak algoritmanın arama aralığının yarısını elemeye devam etmesiyle gerçekleşir.
Örneğin, dizide 16 eleman varsa, arama aralığı şöyle olur:
16 → 8 → 4 → 2 → 1Adım sayısı doğrusal olarak değil, logaritmik olarak artar.
Bu nedenle, ortalama durum zaman karmaşıklığı şudur:
O(log n)En Kötü Durum Zaman Karmaşıklığı: O(log n)
En kötü durum, hedefin kontrol edilebilecek son konumda olması veya hedefin dizide mevcut olmamasıyla gerçekleşir.
Bu durumda bile, İkili Arama her elemanı kontrol etmez. Her adımda arama aralığını hala ikiye böler.
Örneğin, 1.024 elemanla:
1024 → 512 → 256 → 128 → 64 → 32 → 16 → 8 → 4 → 2 → 1Bu yaklaşık 10 adım sürer çünkü:
log2(1024) = 10Bu nedenle, en kötü durum zaman karmaşıklığı şudur:
O(log n)İkili Arama Neden O(log n)
İkili Arama O(log n)'dir çünkü her karşılaştırma, kalan elemanların yarısını değerlendirme dışı bırakır.
Giriş boyutu iki katına çıkarsa, İkili Arama genellikle sadece bir ek adıma ihtiyaç duyar.
Elements: 8 Maximum steps: 3
Elements: 16 Maximum steps: 4
Elements: 32 Maximum steps: 5
Elements: 1024 Maximum steps: 10
Elements: 1,048,576 Maximum steps: 20Bu yavaş büyüme, İkili Arama'yı büyük sıralı veri kümeleri için son derece verimli yapan şeydir.
İkili Arama'nın Uzay Karmaşıklığı
Uzay karmaşıklığı, bir algoritmanın ne kadar ek bellek kullandığını açıklar.
İkili Arama'nın iteratif versiyonu yalnızca birkaç değişken kullanır:
leftrightmiddletarget
Yeni bir dizi veya veri yapısı oluşturmaz.
Bu nedenle, iteratif İkili Arama'nın uzay karmaşıklığı şudur:
O(1)Özyinelemeli versiyon çağrı yığınını kullanır. Özyineleme derinliği O(log n) olduğu için, özyinelemeli İkili Arama'nın uzay karmaşıklığı şudur:
O(log n)İkili Arama ve Doğrusal Arama
İkili Arama ve Doğrusal Arama her ikisi de arama algoritmalarıdır, ancak farklı durumlarda kullanılırlar.
Doğrusal Arama elemanları tek tek kontrol eder. İkili Arama, arama aralığını sürekli olarak ikiye böler.
Temel farklılıklar şunlardır:
Doğrusal Arama sıralanmamış veriler üzerinde çalışır.
İkili Arama sıralı veri gerektirir.
Doğrusal Arama'nın en kötü durum zaman karmaşıklığı O(n)'dir.
İkili Arama'nın en kötü durum zaman karmaşıklığı O(log n)'dir.
Doğrusal Arama daha basittir.
İkili Arama, büyük sıralı diziler için çok daha hızlıdır.
Dizi küçük veya sıralanmamışsa, Doğrusal Arama yeterli olabilir. Dizi büyük ve sıralıysa, İkili Arama genellikle çok daha iyidir.
Tekrar Eden Değerlerle İkili Arama
Sıralı dizi tekrar eden değerler içeriyorsa, normal İkili Arama, eşleşen dizinlerden herhangi birini döndürebilir, zorunlu olarak ilk veya son oluşumu değil.
Örneğin:
Array: [2, 4, 4, 4, 6, 8]
Target: 4İkili Arama, arama sırasında ortadaki dizinin nasıl hesaplandığına bağlı olarak 1, 2 veya 3 dizinini döndürebilir.
Geliştiriciler ilk veya son oluşumu ihtiyaç duyarsa, algoritma değiştirilmelidir.
İlk Oluşumu Bulma
Tekrar eden bir değerin ilk oluşumunu bulmak için, hedefi bulduktan sonra bile sol tarafta aramaya devam ederiz.
<?php
function firstOccurrence(array $numbers, int $target): int
{
$left = 0;
$right = count($numbers) - 1;
$result = -1;
while ($left <= $right) {
$middle = $left + intdiv($right - $left, 2);
if ($numbers[$middle] === $target) {
$result = $middle;
$right = $middle - 1;
} elseif ($numbers[$middle] < $target) {
$left = $middle + 1;
} else {
$right = $middle - 1;
}
}
return $result;
}
$numbers = [2, 4, 4, 4, 6, 8];
echo firstOccurrence($numbers, 4);Çıktı şöyle olacaktır:
1Bu versiyon bulunan dizini saklar ve daha önceki bir oluşumun olup olmadığını görmek için sola doğru aramaya devam eder.
Son Oluşumu Bulma
Son oluşumu bulmak için, hedefi bulduktan sonra sağ tarafta aramaya devam ederiz.
<?php
function lastOccurrence(array $numbers, int $target): int
{
$left = 0;
$right = count($numbers) - 1;
$result = -1;
while ($left <= $right) {
$middle = $left + intdiv($right - $left, 2);
if ($numbers[$middle] === $target) {
$result = $middle;
$left = $middle + 1;
} elseif ($numbers[$middle] < $target) {
$left = $middle + 1;
} else {
$right = $middle - 1;
}
}
return $result;
}
$numbers = [2, 4, 4, 4, 6, 8];
echo lastOccurrence($numbers, 4);Çıktı şöyle olacaktır:
3Bu versiyon bulunan dizini saklar ve son eşleşen konumu bulmak için sağa doğru aramaya devam eder.
Azalan Dizilerde İkili Arama
İkili Arama azalan sırada sıralanmış diziler üzerinde de çalışabilir, ancak karşılaştırma mantığı tersine çevrilmelidir.
Örneğin:
[18, 16, 14, 12, 10, 8, 6, 4, 2]Artan bir dizide, ortadaki değer hedeften küçükse sağa doğru ararız. Azalan bir dizide, ortadaki değer hedeften küçükse sola doğru ararız.
Bu nedenle geliştiriciler, İkili Arama'yı uygulamadan önce sıralama yönünü bilmelidir.
Cevap Üzerinde İkili Arama
İkili Arama sadece bir dizide bir eleman bulmak için kullanılmaz. Problem monoton bir koşula sahip olduğunda, sayısal bir aralıkta bir cevap bulmak için de kullanılabilir.
Monoton bir koşul, bir koşul doğru hale geldiğinde o noktadan sonra doğru kalması veya yanlış hale geldiğinde o noktadan sonra yanlış kalması anlamına gelir.
Örnekler şunlardır:
Paketleri belirli sayıda gün içinde göndermek için gereken minimum kapasiteyi bulma.
Bir görevi son teslim tarihinden önce bitirmek için gereken en küçük hızı bulma.
Bir versiyon dizisinde ilk hatalı versiyonu bulma.
Sıralı bir aralıkta bir alt sınır veya üst sınır bulma.
Bu teknik genellikle “Cevap Üzerinde İkili Arama” olarak adlandırılır ve problem çözmede ve rekabetçi programlamada yaygındır.
Alt Sınır ve Üst Sınır
İkili Arama, kesin değerler yerine sınırları bulmak için değiştirilebilir.
Alt sınır genellikle, bir değerin sıralı düzeni bozmadan eklenebileceği ilk konumu ifade eder. Hedeften büyük veya hedefe eşit ilk elemanı bulur.
Üst sınır genellikle hedeften büyük ilk konumu ifade eder.
Bu varyantlar, tekrarlar, aralıklar, sıralı listeler ve ekleme konumları ile çalışırken faydalıdır.
Geliştiriciler İkili Aramayı Ne Zaman Kullanmalı?
Geliştiriciler, veri sıralı olduğunda ve hızlı arama gerektiğinde İkili Arama'yı kullanmalıdır.
İkili Arama şu durumlarda faydalıdır:
Dizi sıralıdır.
Veri kümesi büyüktür.
Arama işlemleri sık sık yapılır.
Dizin ile rastgele erişim mevcuttur.
Arama problemi ikiye bölünebilir.
Logaritmik bir çözüme ihtiyaç vardır.
Problem monoton bir koşula sahiptir.
İkili Arama, özellikle büyük sıralı dizilerde arama yaparken veya aralık tabanlı algoritmik problemleri çözerken güçlüdür.
İkili Arama Ne Zaman Kullanılmaz
İkili Arama, veri sıralanmamış olduğunda ve önce sıralamanın maliyeti buna değmediğinde kullanılmamalıdır.
Geliştiriciler İkili Arama'dan şu durumlarda kaçınmalıdır:
Dizi sıralı değildir.
Veri kümesi çok küçüktür ve Doğrusal Arama daha basittir.
Veri yapısı hızlı rastgele erişimi desteklemez.
Karşılaştırma kuralı tutarlı değildir.
Veriler sürekli değişir ve sıralı tutmak maliyetlidir.
Veri sıralanmamış ve sadece bir arama gerekiyorsa, Doğrusal Arama önce sıralayıp sonra İkili Arama uygulamaktan daha pratik olabilir.
Pratik Örnek: Ürün Fiyatlarını Arama
Sıralı bir ürün fiyatları listesi olan bir e-ticaret sistemi düşünün. Belirli bir fiyatın var olup olmadığını kontrol etmemiz gerekirse, İkili Arama bunu verimli bir şekilde yapabilir.
<?php
$prices = [19, 29, 49, 79, 99, 149, 199];
echo binarySearch($prices, 79);Çıktı şöyle olacaktır:
379 fiyatı 3. dizinde mevcut.
Pratik Örnek: Kullanıcı Kimliklerini Arama
Kullanıcı kimlikleri sıralı düzende saklanıyorsa, İkili Arama belirli bir kimliğin var olup olmadığını hızlıca kontrol edebilir.
User IDs:
[101, 105, 109, 120, 135, 150, 180]
Target:
135İkili Arama, her kimliği tek tek kontrol etmeden 135'i bulabilir.
Gerçek arka uç sistemlerinde, veritabanı indeksleri genellikle bu tür aramayı daha verimli bir şekilde halleder. Ancak, indeksli aramanın arkasındaki fikir, mümkün olduğunda tam doğrusal taramaları önlemekle ilgilidir.
İkili Arama Uygularken Yapılan Yaygın Hatalar
İkili Arama kavram olarak basit olsa da, birçok geliştirici onu uygularken hata yapar.
Yaygın hatalar şunlardır:
Sıralanmamış bir dizi üzerinde İkili Arama kullanmak.
Yanlış döngü koşulu kullanmak.
leftveyaright'i güncellemeyi unutmak.middle'imiddle + 1veyamiddle - 1yerine tekrar kullanmak.Sonsuz döngü oluşturmak.
Ortadaki dizini yanlış hesaplamak.
Boş dizileri işlememek.
Normal bir İkili Arama'nın her zaman ilk tekrarı döndürmesini beklemek.
En önemli kural, her karşılaştırmadan sonra arama aralığını doğru bir şekilde küçültmektir.
İkili Aramayı Anlamak İçin Pratik Kontrol Listesi
Gelişmiş arama problemlerine geçmeden önce, geliştiriciler şu soruları yanıtlayabilmelidir:
Dizi neden sıralı olmalıdır?
leftverightneyi temsil eder?Ortadaki dizin nasıl hesaplanır?
Algoritma sol yarıyı ne zaman aramalıdır?
Algoritma sağ yarıyı ne zaman aramalıdır?
Durdurma koşulu nedir?
Zaman karmaşıklığı neden O(log n)'dir?
İteratif ve özyinelemeli İkili Arama arasındaki fark nedir?
Tekrarlar nasıl ele alınmalıdır?
Bu sorular netse, geliştirici kodu sadece ezberlemek yerine İkili Arama'yı derinlemesine anlar.
İkili Arama'nın Avantajları
İkili Arama'nın birkaç önemli avantajı vardır.
Büyük sıralı diziler için çok verimlidir.
O(log n) ortalama ve en kötü durum zaman karmaşıklığına sahiptir.
İteratif versiyonda O(1) ek bellek kullanır.
İlk oluşum, son oluşum, alt sınır ve üst sınır için uyarlaması kolaydır.
Logaritmik düşünme ve böl-yönet mantığını öğretir.
Basit aramanın ötesinde birçok algoritmik problemde faydalıdır.
Bu avantajlar, İkili Arama'yı geliştiricilerin ustalaşması gereken en önemli algoritmalardan biri yapar.
İkili Arama'nın Dezavantajları
İkili Arama'nın sınırlamaları da vardır.
Sıralı veri gerektirir.
Doğrusal Arama'dan daha karmaşıktır.
Hızlı dizin erişimi olmayan veri yapıları için ideal değildir.
Önce sıralama gerektirebilir, ki bunun da kendi maliyeti vardır.
Sınır güncellemeleri yanlışsa yanlış uygulanabilir.
Bu sınırlamalar nedeniyle, İkili Arama yalnızca gereksinimleri karşılandığında güçlüdür.
Gerçek Yazılım Projelerinde İkili Arama
Gerçek yazılım projelerinde, geliştiriciler genellikle her arama problemi için İkili Arama'yı manuel olarak uygulamazlar. Programlama dilleri, veritabanları, arama motorları ve kütüphaneler genellikle optimize edilmiş arama ve indeksleme mekanizmaları sağlar.
Ancak, İkili Arama'yı anlamak hala değerlidir çünkü aynı fikir birçok yerde karşımıza çıkar. Veritabanı indeksleri, sıralı koleksiyonlar, aralık sorguları, sayfalama sınırları, versiyon kontrolleri, optimizasyon problemleri ve algoritma zorlukları genellikle ikili arama düşüncesine dayanır.
Arka uç geliştiricileri için İkili Arama, indekslenmiş sorguların neden her kaydı taramaktan daha hızlı olduğu konusunda daha güçlü bir sezgi oluşturmaya da yardımcı olur.
Sonuç
İkili Arama, sıralı bir dizideki hedef değeri arama aralığını sürekli olarak ikiye bölerek bulan verimli bir arama algoritmasıdır.
Hedef hemen bulunduğunda en iyi durum zaman karmaşıklığı O(1)'dir. Ortalama ve en kötü durum zaman karmaşıklığı O(log n)'dir, bu da onu büyük sıralı veri kümeleri için Doğrusal Arama'dan çok daha hızlı yapar.
En önemli gereklilik, verilerin sıralı olmasıdır. Sıralı veri olmadan, İkili Arama sol yarıda mı yoksa sağ yarıda mı aranacağına güvenilir bir şekilde karar veremez.
İkili Arama iteratif veya özyinelemeli olarak uygulanabilir. İteratif versiyon O(1) ek alan kullanırken, özyinelemeli versiyon O(log n) yığın alanı kullanır. Algoritma ayrıca tekrarları, alt sınırları, üst sınırları ve cevap arama problemlerini ele almak için de genişletilebilir.
Veri yapıları ve algoritmaları öğrenen geliştiriciler için İkili Arama esastır. Verimli aramayı, sınır kontrolünü, logaritmik karmaşıklığı ve bir problemi her adımda yarıya indirme gücünü öğretir.

