Kabarcık sıralaması - Vikipedi
İçeriğe atla
Ana menü
Gezinti
  • Anasayfa
  • Hakkımızda
  • İçindekiler
  • Rastgele madde
  • Seçkin içerik
  • Yakınımdakiler
Katılım
  • Deneme tahtası
  • Köy çeşmesi
  • Son değişiklikler
  • Dosya yükle
  • Topluluk portalı
  • Wikimedia dükkânı
  • Yardım
  • Özel sayfalar
Vikipedi Özgür Ansiklopedi
Ara
  • Bağış yapın
  • Hesap oluştur
  • Oturum aç
  • Bağış yapın
  • Hesap oluştur
  • Oturum aç

İçindekiler

  • Giriş
  • 1 İnceleme
    • 1.1 Algoritmanın Karmaşıklığı
    • 1.2 Algoritmanın Adım Adım İşleyişi
    • 1.3 Sözde Kodu
  • 2 Diğer Sıralama Algoritmaları
  • 3 Dış bağlantılar

Kabarcık sıralaması

  • العربية
  • الدارجة
  • Azərbaycanca
  • Български
  • भोजपुरी
  • বাংলা
  • Català
  • Čeština
  • Dansk
  • Deutsch
  • Ελληνικά
  • English
  • Esperanto
  • Español
  • Eesti
  • فارسی
  • Suomi
  • Français
  • עברית
  • हिन्दी
  • Magyar
  • Հայերեն
  • Íslenska
  • İtaliano
  • 日本語
  • ქართული
  • Қазақша
  • ಕನ್ನಡ
  • 한국어
  • Kurdî
  • Lëtzebuergesch
  • Lombard
  • Lietuvių
  • മലയാളം
  • Nederlands
  • Norsk bokmål
  • Polski
  • Português
  • Русский
  • Simple English
  • Slovenčina
  • Slovenščina
  • Српски / srpski
  • Svenska
  • ไทย
  • Tagalog
  • Українська
  • Tiếng Việt
  • 中文
  • 粵語
Bağlantıları değiştir
  • Madde
  • Tartışma
  • Oku
  • Değiştir
  • Kaynağı değiştir
  • Geçmişi gör
Araçlar
Eylemler
  • Oku
  • Değiştir
  • Kaynağı değiştir
  • Geçmişi gör
Genel
  • Sayfaya bağlantılar
  • İlgili değişiklikler
  • Kalıcı bağlantı
  • Sayfa bilgisi
  • Bu sayfayı kaynak göster
  • Kısaltılmış URL'yi al
  • Karekodu indir
Yazdır/dışa aktar
  • Bir kitap oluştur
  • PDF olarak indir
  • Basılmaya uygun görünüm
Diğer projelerde
  • Wikimedia Commons
  • Vikiveri ögesi
Görünüm
Vikipedi, özgür ansiklopedi
Kabarcık sıralaması
Kabarcık sıralaması'nın rastgele üretilmiş sayıları sıraladığını gösteren bir örnek
SınıfSıralama algoritması
Veri yapısıDizi
Zaman karmaşıklığıО(n²)
En iyiYok
Alan karmaşıklığıtoplamda О(n), ek alan O(1)
Kabarcık sıralamasının durağan gösterimi
Kabarcık sıralamasının durağan gösterimi

Kabarcık Sıralaması, bilgisayar bilimlerinde kullanılan yalın bir sıralama algoritmasıdır. Sıralanacak dizinin üzerinde sürekli ilerlerken her defasında iki öğenin birbiriyle karşılaştırılıp, karşılaştırılan öğelerin yanlış sırada olmaları durumunda yerlerinin değiştirilmesi mantığına dayanır. Algoritma, herhangi bir değişiklik yapılmayıncaya kadar dizinin başına dönerek kendisini yineler. Adına "Kabarcık" sıralaması denmesinin nedeni büyük olan sayıların aynı suyun altındaki bir kabarcık gibi dizinin üstüne doğru ilerlemesidir.

Başlangıçta yer yer değiştirme sıralaması olarak adlandırılan kabarcık sıralaması, dizi içindeki büyük elemanların algoritmanın her adımında dizinin sonuna doğru doğrusal olarak ilerlemesini sağlar. Bu ilerleme, seçmeli sıralama algoritmasındaki dizideki değeri küçük olan elemanların dizinin başında kümelenmesi yöntemine benzer şekilde gerçekleşir.

İnceleme

[değiştir | kaynağı değiştir]

Kabarcık sıralaması dizinin başından başlar ve dizi elemanlarını sırayla seçer. Seçilen dizi elemanı kendinden sonra gelen elemandan büyükse bu iki elemanın yerleri değiştirilir. Bu işlem sonucunda dizinin en büyük elemanı dizi sonuna yerleştirildiğinden bir sonraki adımda arama sınırı bir eleman geri çekilir. Bu işlem, dizinin sonundaki elemanın karşılaştırılmasına kadar yinelenerek sürdürülür.

Algoritmanın Karmaşıklığı

[değiştir | kaynağı değiştir]

Kabarcık sıralama algoritmasının ortalama ve en kötü durumdaki karmaşıklığı O ( n 2 ) {\displaystyle {\mathcal {O}}(n^{2})} {\displaystyle {\mathcal {O}}(n^{2})}'dir. Algoritma ortalama ve en kötü durumda ( n 2 / 2 ) {\displaystyle {\mathcal {(}}n^{2}/2)} {\displaystyle {\mathcal {(}}n^{2}/2)} adet karşılaştırma ve yer değiştirme gerçekleştirir.

Algoritmanın Adım Adım İşleyişi

[değiştir | kaynağı değiştir]

İçeriği "5 1 4 2 8" olan bir dizi kabarcık sıralaması ile en küçükten en büyüğe doğru aşağıdaki biçimde sıralanır. Her adımda dizinin kalın olarak işaretlenmiş elemanları karşılaştırılan elemanlardır.

Birinci Geçiş:
(5 1 4 2 8 ) → {\displaystyle \to } {\displaystyle \to } (1 5 4 2 8 ) Burada algoritma ilk iki elemanı karşılaştırır ve yerlerini değiştirir.
(1 5 4 2 8 ) → {\displaystyle \to } {\displaystyle \to } (1 4 5 2 8 )
(1 4 5 2 8 ) → {\displaystyle \to } {\displaystyle \to } (1 4 2 5 8 )
(1 4 2 5 8) → {\displaystyle \to } {\displaystyle \to } (1 4 2 5 8) Burada elemanlar zaten sıralı olduğu için algoritma yerlerini değiştirmez.
İkinci Geçiş:
(1 4 2 5 8 ) → {\displaystyle \to } {\displaystyle \to } (1 4 2 5 8 )
(1 4 2 5 8 ) → {\displaystyle \to } {\displaystyle \to } (1 2 4 5 8 )
(1 2 4 5 8 ) → {\displaystyle \to } {\displaystyle \to } (1 2 4 5 8 )
(1 2 4 5 8) → {\displaystyle \to } {\displaystyle \to } (1 2 4 5 8)
Artık dizi sıralıdır ancak algoritma işlemin bittiğini bilmemektedir. Algoritmanın dizinin sıralandığını anlaması için bütün dizinin üzerinden hiçbir değişiklik yapmadan tam bir geçiş yapması gerekir.
Üçüncü Geçiş:
(1 2 4 5 8 ) → {\displaystyle \to } {\displaystyle \to } (1 2 4 5 8 )
(1 2 4 5 8 ) → {\displaystyle \to } {\displaystyle \to } (1 2 4 5 8 )
(1 2 4 5 8 ) → {\displaystyle \to } {\displaystyle \to } (1 2 4 5 8 )
(1 2 4 5 8) → {\displaystyle \to } {\displaystyle \to } (1 2 4 5 8)
Sonuç olarak dizi sıralanmıştır ve algoritma sonlanır.

Sözde Kodu

[değiştir | kaynağı değiştir]

Algoritmanın yalın bir sözde kod olarak gösterimi aşağıdaki gibidir:

procedure bubbleSort(A : sıralanabilir öğe dizisi ) defined as:
  do
    swapped := false
    for each i in 0 to length(A ) - 2 do:
      if A[ i ] > A[ i + 1 ] then
        swap(A[ i ], A[ i + 1 ] )
        swapped := true
      end if
    end for
  while swapped
end procedure </gösterilebilir:

procedure bubbleSort( A : sıralanabilir öğe dizisi ) defined as:
  for each i in 1 to length(A) do:
    for each j in length(A) downto i + 1 do:
       if A[ j -1  ] > A[ j ] then
         swap( A[ j - 1],  A[ j ] )
       end if
     end for
  end for
end procedure 

Diğer Sıralama Algoritmaları

[değiştir | kaynağı değiştir]
  • Hızlı Sıralama
  • Birleştirmeli Sıralama
  • Seçmeli Sıralama
  • Kokteyl Sıralaması
  • Tarak Sıralaması
  • Yığın Sıralaması
  • Eklemeli Sıralama
  • Kabuk Sıralaması

Dış bağlantılar

[değiştir | kaynağı değiştir]
  • K 28 Kasım 2020 tarihinde Wayback Machine sitesinde arşivlendi.

abarcık Sıralama MATLAB 28 Kasım 2020 tarihinde Wayback Machine sitesinde arşivlendi. Kod Örneği 28 Kasım 2020 tarihinde Wayback Machine sitesinde arşivlendi.

  • Kabarcık Sıralama Python 28 Kasım 2020 tarihinde Wayback Machine sitesinde arşivlendi. Kod Örneği 28 Kasım 2020 tarihinde Wayback Machine sitesinde arşivlendi.
    • 20 programlama dilinde yazılmış Kabarcık Sıralaması örnekleri 6 Şubat 2008 tarihinde Wayback Machine sitesinde arşivlendi.
    • Kabarcık Sıralaması'nın güzel görünümlü bir örneği ve örneğin kaynak kodu
    • Java Applet olarak Kabarcık Sıralaması 20 Ekim 2007 tarihinde Wayback Machine sitesinde arşivlendi.
    • Kabarcık Sıralaması örneği
    • Kabarcık Sıralaması örneği - 2 29 Ocak 2008 tarihinde Wayback Machine sitesinde arşivlendi.
    • Kabarcık Sıralaması örneği - 3 19 Ocak 2008 tarihinde Wayback Machine sitesinde arşivlendi.
    • Kabarcık Sıralaması örneği - 4 (İspanyolca) 19 Şubat 2008 tarihinde Wayback Machine sitesinde arşivlendi.
    • C++ ile yazılmış sıralama uygulamacıkları 24 Şubat 2008 tarihinde Wayback Machine sitesinde arşivlendi.
    • Kabarcık Sıralaması'nı uygulayan C++ programı 2 Şubat 2008 tarihinde Wayback Machine sitesinde arşivlendi.
    • Kabarcık Sıralaması'nı uygulayan C++ programı ve açıklaması
    • Kabarcık Sıralaması görüntüsü ve C++ kodu
    • Kabarcık Sıralaması'nı Javascript IDE kullanarak incelemeyi sağlayan bir araç
    • Kabarcık Sıralaması'nın C++ ve Java örnekleri
"https://tr.wikipedia.org/w/index.php?title=Kabarcık_sıralaması&oldid=32541969" sayfasından alınmıştır
Kategori:
  • Sıralama algoritmaları
Gizli kategori:
  • Webarşiv şablonu wayback bağlantıları
  • Sayfa en son 16.11, 21 Nisan 2024 tarihinde değiştirildi.
  • Metin Creative Commons Atıf-AynıLisanslaPaylaş Lisansı altındadır ve ek koşullar uygulanabilir. Bu siteyi kullanarak Kullanım Şartlarını ve Gizlilik Politikasını kabul etmiş olursunuz.
    Vikipedi® (ve Wikipedia®) kâr amacı gütmeyen kuruluş olan Wikimedia Foundation, Inc. tescilli markasıdır.
  • Gizlilik politikası
  • Vikipedi hakkında
  • Sorumluluk reddi
  • Davranış Kuralları
  • Geliştiriciler
  • İstatistikler
  • Çerez politikası
  • Mobil görünüm
  • Wikimedia Foundation
  • Powered by MediaWiki
Kabarcık sıralaması
Konu ekle