PC ve web geliştirmeden mobil cihazlar veya gömülü sistemler için kodlamaya geçiş yapan programcılar, kendi veri yapılarını ve algoritmalarını seçmek ve kodlamak için daha fazla zaman harcadıklarını görüyorlar. Daha az bellek ve sınırlı veri depolama ile önceden oluşturulmuş kitaplıklara veya çerçevelere yer yoktur. Bu nedenle, kendi sıralama rutinlerini yazması gerekenler için, düşük kabarcıklı sıralamayı seçme konusunda bazı hususlar aşağıda verilmiştir.
Arka plan
Kabarcık sıralama, bellekteki öğelerin listesini sıralayan basit bir algoritmadır. Bir dizi verildiğinde, kod her bir bitişik öğe çiftini tekrar tekrar karşılaştırır ve sıralı değilse bunları değiştirir. İşlem, daha fazla takas gerçekleşene kadar tekrarlanır. Sıralama devam ederken diziyi görüntülemek mümkün olsaydı, düşük değerler üstte "kabarcık" olurken, büyük değerler altta batardı. İşte Visual Basic 2010'daki ilgili kod:
Günün Videosu
while takas = True swap = False For i = 0 To tbl.length - 2 Eğer tbl (i) > tbl (i + 1) ise tmp = tbl (i) tbl (i) = tbl (i + 1) tbl (i + 1) = tmp takas = True End If Next End iken
Balon Sıralaması Ne Zaman Seçilmelidir?
Bu algoritmanın çeşitli avantajları vardır. Yazması basit, anlaşılması kolay ve sadece birkaç satır kod gerektiriyor. Veriler yerinde sıralanır, böylece çok az bellek yükü olur ve sıralandıktan sonra veriler bellekte işlenmeye hazır hale gelir. En büyük dezavantajı, sıralama için gereken süredir. Tablo öğelerinin sayısı arttıkça ortalama süre neredeyse üssel olarak artar. Öğe sayısının on katı, sıralamak neredeyse yüz kat daha uzun sürer.
Diğer Dizi Sıralamaları
Sıralama algoritmaları karmaşıklık, hız ve ek yük bakımından farklılık gösterir. Kabarcık sıralama en az karmaşık ama aynı zamanda en yavaş olanlardan biridir. Ekleme sıralama ve değiş tokuş sıralama gibi diğer dizi tabanlı sıralamalar biraz daha hızlıdır ancak daha fazla kod alır (aşağıdaki referanslara bakın). Dizi tabanlı sıralamaların ana avantajı, en az kodu kullanmaları ve en az miktarda çalışan bellek kullanmalarıdır. Birkaç yüzden az öğe içeren basit diziler için bu türleri düşünün.
Karmaşık Sıralama Algoritmaları
Daha büyük veri kümeleri, daha karmaşık kod ve daha fazla bellek gerektirir. Hızlı sıralama ve yığın sıralama, karşılaştırma sayısını optimize etmek için veri kümelerini hem böler hem de kopyalar. Hızlı sıralama, listeyi sürekli olarak böler ve ardından sıralı düzende yeniden birleştirir. Yığın sıralama, verileri bir ağaç yapısına kopyalar ve ardından verileri tekrar sıraya kopyalamak için ağaçta gezinir. Her ikisi de hızlı ve verimlidir ancak daha fazla kod ve çok daha fazla çalışan depolama alanı gerektirir. Büyük veri kümeleri için bu algoritmaları seçin.