Ara:

Şu an misafir modundasın. YazılımDevi olmak ister misin? Giriş Yap / Kayıt Ol

Makale Hakkında!

C# ile Bubble Sort Algoritmasi Makale Yazarı Okunma Sayısı Eklenme Tarihi
Veysel Uğur Kizmaz 1601 22.02.2009

Makale Detayı

Uygulanmasi en basit olan siralama algoritmasidir.

Dizilerin elemanlarini birbiriyle karsilastirip büyüklügüne göre yer degistirme yapar.

Bir örnek üzerinde inceleyecek olursak:
Örnegimizde küçükten büyüge siralama yapacagiz.

1. Adim:
8 0 3 5 2 4  --  0 8 3 5 2 4
0 8 3 5 2 4  --  0 3 8 5 2 4
0 3 8 5 2 4  --  0 3 5 8 2 4
0 3 5 8 2 4  --  0 3 5 2 8 4
0 3 5 2 8 4  --  0 3 5 2 4 8 (8 elemaninin en büyük oldugunu bulduk ve dizinin son elemani olarak atadik. Bundan sonra bu elemani kontrol etmeyecegiz)

2. Adim:
0 3 5 2 4 8  --  0 3 5 2 4 8
0 3 5 2 4 8  --  0 3 5 2 4 8
0 3 5 2 4 8  --  0 3 2 5 4 8
0 3 2 4 5 8  --  0 3 2 4 5 8 (5 elemaninin kendinden önceki elemanlardan büyük oldugunu bulduk ve sondan 2. siraya yerlestirdik)

3. Adim:
0 3 2 4 5 8  --  0 3 2 4 5 8
0 3 2 4 5 8  --  0 2 3 4 5 8
0 2 3 4 5 8  --  0 2 3 4 5 8 (4 elemaninin kendinden önceki elemanlardan büyük oldugunu bulduk ve sondan 3. siraya yerlestirdik)

4. Adim:
0 2 3 4 5 8  --  0 2 3 4 5 8
0 2 3 4 5 8  --  0 2 3 4 5 8 (3 elemaninin kendinden önceki elemanlardan büyük oldugunu bulduk ve sondan 4. siraya yerlestirdik)

5. Adim:
0 2 3 4 5 8  --  0 2 3 4 5 8 (2 elemaninin kendinden önceki elemanlardan büyük oldugunu bulduk ve sondan 5. siraya yerlestirdik)

C# kodu asagidaki gibidir:

 

        public void BubbleSort(int[] dizi)
        {
            int gecici;
 
            for (int i = 0; i <= dizi.Length - 1; i++)
            {
                for (int j = 1; j <= dizi.Length - 1; j++)
                {
                    if (dizi[j - 1] > dizi[j])
                    {
                        gecici = dizi[j - 1];
                        dizi[j - 1] = dizi[j];
                        dizi[j] = gecici;
                    }
                }
            }
        }
 veya
        public void BubbleSort2(int[] dizi)
        {
            int[] dizi = { 8, 0, 3, 5, 2, 4 };
            int gecici;
 
            for (int i = dizi.Length - 1; i >= 0; i--)
            {
                for (int j = 1; j <= dizi.Length - 1; j++)
                {
                    if (dizi[j - 1] > dizi[j])
                    {
                        gecici = dizi[j - 1];
                        dizi[j - 1] = dizi[j];
                        dizi[j] = gecici;
                    }
                }
            }
        }
 
 
Veysel Ugur KIZMAZ


Makale Tagları

Makale Dosyası

Makaleye Ait Dosya Bulunamamıştır

Paylaş


Yazar Hakkında
Genel Bilgiler   Yazar Hakkında
Ad: Veysel Uğur Kizmaz 1986 doğumlu Veysel Uğur Kızmaz, Gazi Üniversitesi Bilgisayar Mühendisliği bölümü mezunu, Ankara Üniversitesi Bilgisayar Mühendisliği bölümünde yüksek lisans öğrencisidir. Bir çok projede çalışmış olan yazarımız, şu an özel bir yazılım firmasında web tabanlı sistemler üzerinde çalışmalar yapmaktadır. Yazarımızın uzmanlaştığı alanlar .Net, Java, Php, Javascript, SQL Server, Oracle, MySQL, Sharepoint, Team Foundation Server, Biztalk, WCF, Test ve Modellemedir. Sertifikaları : MCTS
Kurum: Özel bir yazılım firması
Meslek: Yazılım Mühendisi
E-Mail: veysel@ugurkizmaz.com
Web Sitesi: http://www.ugurkizmaz.com
Makale-Video: 214

Bu makale için yapılmış yorumlar

Bu makale hakkında yorum yapınız!...

Bu makale hakkında yorum yapabilmek için lütfen üye olunuz veya giriş yapınız.

Konular

Yazarlar

Son Eklenen Makaleler

Son Eklenen Videolar

Ziyaretçi İstatistiği

ImageOnline : 10         Bugün : 1374

Bu Ay : 8205        Bu Yıl : 58379

Toplam : 441218

Kullanıcı Giriş Paneli!
E-Mail:
Şifreniz:
Giriş Yap

Şifremi Unuttum!
E-Mail:
    Gönder