Binary search nasıl yapılır?
Binary Search Nedir?
Binary search, sıralı bir dizide belirli bir öğeyi hızlı bir şekilde bulmak için kullanılan etkili bir algoritmadır. Bu algoritma, diziyi sürekli olarak ortadan ikiye bölerek arama yapar.Binary Search Nasıl Yapılır?
1. **Diziyi Sırala:** Eğer dizi sıralı değilse, öncelikle sıralanması gerekir. 2. **Başlangıç ve Bitiriş Noktalarını Belirle:** - İlk elemanı göstermek için bir \"başlangıç\" indeksi (genellikle 0) ve son elemanı göstermek için bir \"bitiş\" indeksi (dizinin uzunluğu - 1) belirleyin. 3. **Ortayı Hesapla:** - Ortada bulunan elemanın indeksi şu şekilde hesaplanır: - `orta = (başlangıç + bitiriş) / 2` 4. **Karşılaştırma Yap:** - Eşleşen öğeyi bulmak için aşağıdaki durumlardan birini kontrol edin: - Eğer aranan öğe ortadaki öğeye eşitse, öğe bulunmuştur. - Eğer aranan öğe ortadaki öğeden küçükse, \"bitiriş\" indeksini ortanın bir öncesine ayarlayın. - Eğer aranan öğe ortadaki öğeden büyükse, \"başlangıç\" indeksini ortanın bir sonrasına ayarlayın. 5. **Tekrarla:** - Adımları, \"başlangıç\" indeksi \"bitiriş\" indeksinden küçük olduğu sürece tekrarlayın. 6. **Sonuç:** - Öğeyi bulamazsanız, dizide yok demektir.Örnek Uygulama
- Dizi: [2, 3, 4, 10, 40] - Aranan Öğe: 10 Adımlar: - Başlangıç = 0, Bitiriş = 4 - Orta = (0 + 4) / 2 = 2 ⇒ 4 ile karşılaştır. - 10 > 4, Başlangıç = 3 - Orta = (3 + 4) / 2 = 3 ⇒ 10 ile karşılaştır. - 10 = 10, öğe bulundu. Binary search, uygun bir sıraya sahip dizilerde performans açısından oldukça etkilidir ve O(log n) zaman karmaşıklığına sahiptir.
Cevap yazmak için lütfen
.
Aynı kategoriden
- SQL injection nedir, yüksek seviyede nasıl önlenir?
- Bubble sort nasıl çalışır?
- Makine öğrenmesi algoritmalarının performansını iyileştirmek için kullanılan çapraz doğrulama yöntemlerinin avantajları ve sınırlamaları nelerdir
- Yeni başladım: Mühendislik alanında kullanılan temel tasarım desenleri nelerdir?
- Fonksiyonel programlama nedir?
- Bilişim nedir?
- İkili arama (binary search) hangi ön koşulları gerektirir?
- Clean code prensipleri nelerdir?
- WebSocket nedir, hangi senaryolarda tercih edilir?
- Bağlı liste (linked list) nedir?
- Arduino programlama dilinde en sık kullanılan komutlar hangileridir?
- Veri tabanı ilişkileri nedir?
- Belge tabanlı ve anahtar-değer veritabanları ne zaman seçilir?
- Mobil uygulamalar geliştirmek için hangi programlama dilleri tercih edilmelidir?
- Linux’ta terminal komutları
- Amortize analiz nedir, örnekleri nelerdir?
- Bellek yönetimi: stack ve heap farkı nedir?
- Uzak Masaüstü RDP Portunu Değiştirmek
- İndeks nedir ve performansı nasıl etkiler?
- Merge sort nedir?
