Programmeurs die overschakelen van pc- en webontwikkeling naar codering voor mobiele apparaten of embedded systemen, merken dat er meer tijd wordt besteed aan het selecteren en coderen van hun eigen datastructuren en algoritmen. Met minder geheugen en beperkte gegevensopslag is er geen ruimte voor kant-en-klare bibliotheken of frameworks. Dus voor degenen die hun eigen sorteerroutines moeten schrijven, volgen hier enkele overwegingen bij het kiezen van de eenvoudige bubbelsoort.
Achtergrond
De bellensortering is een eenvoudig algoritme dat een lijst met items in het geheugen sorteert. Gegeven een array, vergelijkt de code herhaaldelijk elk paar aangrenzende items en verwisselt ze als ze niet in de juiste volgorde staan. Het proces wordt herhaald totdat er geen swaps meer plaatsvinden. Als het mogelijk zou zijn om de array te bekijken terwijl het sorteren aan de gang is, zouden de lage waarden naar boven "borrelen" terwijl de grote waarden naar de bodem zouden zinken. Hier is de relevante code in Visual Basic 2010:
Video van de dag
While swap = True swap = False For i = 0 To tbl.length - 2 If tbl (i) > tbl (i + 1) Dan tmp = tbl (i) tbl (i) = tbl (i + 1) tbl (i + 1) = tmp swap = True End If Next End While
Wanneer kies je de bubbelsortering?
Dit algoritme heeft verschillende voordelen. Het is eenvoudig te schrijven, gemakkelijk te begrijpen en er zijn maar een paar regels code voor nodig. De gegevens worden op hun plaats gesorteerd, dus er is weinig geheugenoverhead en, eenmaal gesorteerd, bevinden de gegevens zich in het geheugen, klaar voor verwerking. Het grote nadeel is de hoeveelheid tijd die nodig is om te sorteren. De gemiddelde tijd neemt bijna exponentieel toe naarmate het aantal tabelelementen toeneemt. Tien keer zoveel items duurt bijna honderd keer zo lang om te sorteren.
Andere array-sorteringen
Sorteeralgoritmen variëren in complexiteit, snelheid en overhead. De bellensoort is de minst complexe maar ook een van de langzaamste. Andere op arrays gebaseerde sorteringen zoals de invoegsortering en de uitwisselsortering zijn iets sneller, maar vereisen meer code (zie de referenties hieronder). Het belangrijkste voordeel van op arrays gebaseerde sorteringen is dat ze de minste code gebruiken en de minste hoeveelheid werkgeheugen in beslag nemen. Overweeg deze soorten voor eenvoudige arrays met minder dan een paar honderd items.
Complexe sorteeralgoritmen
Grotere datasets vereisen complexere code en meer geheugen. De snelle sortering en heapsortering splitsen en kopiëren de datasets om het aantal vergelijkingen te optimaliseren. De snelle sortering verdeelt de lijst voortdurend en stelt deze vervolgens weer in gesorteerde volgorde samen. De heap-sortering kopieert de gegevens naar een boomstructuur en doorloopt vervolgens de boom om de gegevens weer in de juiste volgorde te kopiëren. Beide zijn snel en efficiënt, maar nemen meer code en veel meer werkgeheugen in beslag. Kies deze algoritmen voor grote datasets.