Programmører, der skifter fra pc- og webudvikling til kodning til mobile enheder eller indlejrede systemer, oplever, at der bruges mere tid på at vælge og kode deres egne datastrukturer og algoritmer. Med mindre hukommelse og begrænset datalagring er der ikke plads til forudbyggede biblioteker eller rammer. Så for dem, der har brug for at skrive deres egne sorteringsrutiner, er her nogle overvejelser om at vælge den lave boblesort.
Baggrund
Boblesorteringen er en simpel algoritme, der sorterer en liste over elementer i hukommelsen. Givet et array sammenligner koden gentagne gange hvert par af tilstødende elementer og bytter dem, hvis de ikke er i orden. Processen gentages, indtil der ikke forekommer flere ombytninger. Hvis det var muligt at se arrayet, mens sorteringen er i gang, ville de lave værdier "boble" til toppen, mens de store værdier ville synke til bunds. Her er den relevante kode i Visual Basic 2010:
Dagens video
Mens swap = Sand swap = Falsk For i = 0 Til tbl.længde - 2 Hvis tbl (i) > tbl (i + 1) Så tmp = tbl (i) tbl (i) = tbl (i + 1) tbl (i) + 1) = tmp swap = True End If Next End While
Hvornår skal man vælge boblesortering
Denne algoritme har flere fordele. Det er nemt at skrive, let at forstå og det kræver kun et par linjer kode. Dataene er sorteret på plads, så der er lidt hukommelse overhead, og når de er sorteret, er dataene i hukommelsen, klar til behandling. Den største ulempe er den tid, det tager at sortere. Den gennemsnitlige tid stiger næsten eksponentielt, efterhånden som antallet af tabelelementer stiger. Ti gange antallet af varer tager næsten hundrede gange så lang tid at sortere.
Andre array-sorteringer
Sorteringsalgoritmer varierer i kompleksitet, hastighed og overhead. Boblesorten er den mindst komplekse, men også en af de langsomste. Andre array-baserede sorter som indsættelsessortering og udvekslingssortering er lidt hurtigere, men tager mere kode (se referencerne nedenfor). Den største fordel ved array-baserede sorteringer er, at de bruger mindst kode og tager den mindste mængde arbejdshukommelse. Overvej disse typer for simple arrays med mindre end et par hundrede genstande.
Komplekse sorteringsalgoritmer
Større datasæt kræver mere kompleks kode og mere hukommelse. Den hurtige sortering og heap-sortering både opdeler og kopierer datasættene for at optimere antallet af sammenligninger. Den hurtige sortering opdeler løbende listen og samler den derefter i sorteret rækkefølge. Dyngesorteringen kopierer dataene ind i en træstruktur og krydser derefter træet for at kopiere dataene tilbage i rækkefølge. Begge er hurtige og effektive, men kræver mere kode og meget mere fungerende lagerplads. Vælg disse algoritmer til store datasæt.