YazilimDevi.Com {..} Yazılım Devi Olacaksın :)  
Kullanıcı Adı :
Şifre :
 
   
  En Çok İzlenen KonularAnlatım
İzle  C# ile Ado.NET-Tablo Verilerini Projemize AktaralimEngin Demirog
İzle  Active Directory Kurulumu (1)Salih Demirog
İzle  Exchange Server 2003 KurulumuSalih Demirog
ASP.NET
ASP.NET AJAX
BILGISAYAR
C#
CRYSTAL REPORTS
CSS
LINQ
MS ACCESS
MS EXCEL
MS POWERPOINT
MS WORD
POCKET PC
SQL
SQL SERVER
VISUAL BASIC
WPF
ISA SERVER 2006
MS EXCHANGE SERVER
MS OUTLOOK
MS SERVER 2003-2008
 
 

Binary Search (Ikili Arama) algoritmasi, (küçükten büyüge) sirali bir dizi içinde arama yapmayi saglayan algoritmadir.

Çalisma Mantigi

Her adimda aranan degerin dizinin orta degiskenine esit olup olmadigi kontrol ettirilir. Esit degilse bu sefer aranan degerin orta degerden büyük mü küçük mü olduguna bakilir. Büyükse baslangiç indexi orta deger'in bir fazlasina, küçükse bir eksigine esitlenir. Amaç, dizi sirali oldugu için eger aranan eleman ortadakinden büyükse, öncekilerden de büyük olacagindan bir sonraki adimda kontrol ederken baslangiç ve bitis index araligini daraltmaktir.

Binary search algoritmasinin örnek fonksiyonu asagidadir.

        public int IkiliArama(int arananSayi,int[] sayilar)
        {
            int baslangic = 0, bitis = sayilar.GetUpperBound(0), orta = baslangic + bitis / 2;
            while (baslangic <= bitis)
            {
                orta = (baslangic + bitis) / 2;
                if (sayilar[orta] > arananSayi)
                {
                    bitis = orta - 1;
                }
                else if (sayilar[orta] < arananSayi)
                {
                    baslangic = orta + 1;
                }
                else
                {
                    return orta;
                }
            }
 
            return -1;
        }

 

Veysel Ugur KIZMAZ