logo

Bubblesort i Python

Bubblesortering är en enkel sorteringsalgoritm som upprepade gånger går igenom listan, jämför intilliggande element och byter ut dem om de är i fel ordning. Den heter 'Bubblesortering' eftersom mindre element 'bubblar' till toppen av listan. Även om det inte är den mest effektiva sorteringsalgoritmen, är den lätt att förstå och implementera, vilket gör den till en bra utgångspunkt för att lära sig om sorteringsalgoritmer. I den här artikeln kommer vi att fördjupa oss i konceptet Bubble Sort, tillhandahålla en Python-implementation med utdata och diskutera algoritmens tidskomplexitet.

Förstå Bubblesortering

Grundidén bakom Bubble Sort är att iterera genom listan flera gånger, jämföra intilliggande element och byta dem om de inte fungerar. Processen fortsätter tills inga fler byten behövs, vilket indikerar att listan nu är sorterad. Algoritmen har fått sitt namn från hur mindre element gradvis flyttas till toppen av listan, ungefär som bubblor som stiger till ytan.

Låt oss bryta ner stegen i Bubble Sort-algoritmen:

10 till makten 6
  1. Iterera genom listan: Börja från början av listan och jämför varje par av intilliggande element.
  2. Jämför och byt: Om elementen är i fel ordning, byt ut dem. Detta säkerställer att det större elementet 'bubblar upp' och det mindre rör sig nedåt.
  3. Fortsätt att iterera: Upprepa processen för varje par av intilliggande element tills slutet av listan nås.
  4. Upprepa tills sorterad: Fortsätt att iterera genom listan tills inga fler byten behövs. Vid denna tidpunkt är listan sorterad.

Även om Bubble Sort är enkel att förstå, är det inte den mest effektiva sorteringsalgoritmen, särskilt för stora datamängder. Dess tidskomplexitet är O(n^2) i värsta fall, där 'n' är antalet element i listan. Denna kvadratiska tidskomplexitet gör den mindre lämplig för stora datamängder jämfört med mer avancerade sorteringsalgoritmer.

Python-implementering av Bubble Sort

Låt oss nu implementera Bubble Sort i Python och observera dess beteende med en exempellista:

 def bubble_sort(arr): n = len(arr) # Traverse through all array elements for i in range(n): # Last i elements are already sorted, so we don't need to check them for j in range(0, n-i-1): # Swap if the element found is greater than the next element if arr[j] > arr[j+1]: arr[j], arr[j+1] = arr[j+1], arr[j] # Example usage if __name__ == '__main__': # Sample list to be sorted sample_list = [64, 34, 25, 12, 22, 11, 90] # Display the original list print('Original List:', sample_list) # Apply Bubble Sort bubble_sort(sample_list) # Display the sorted list print('Sorted List:', sample_list) 

I den här implementeringen tar bubble_sort-funktionen en lista (arr) som parameter och sorterar den på plats. Den kapslade slingan jämför intilliggande element och byter ut dem om de är i fel ordning. Den yttre slingan ser till att processen upprepas tills hela listan är sorterad.

Utdata och förklaring

Låt oss köra den medföljande Python-koden med exempellistan och observera resultatet:

 Original List: [64, 34, 25, 12, 22, 11, 90] Sorted List: [11, 12, 22, 25, 34, 64, 90] 

Här sorteras den ursprungliga listan [64, 34, 25, 12, 22, 11, 90] framgångsrikt med hjälp av bubbelsorteringsalgoritmen, vilket resulterar i den sorterade listan [11, 12, 22, 25, 34, 64, 90].

hög och hög sort

Algoritmen itererar genom listan flera gånger, jämför och byter element tills hela listan är sorterad. I varje pass 'bubblar' det största osorterade elementet till sin rätta position. Denna process fortsätter tills inga fler byten behövs, vilket indikerar att listan är helt sorterad.

Även om Bubble Sort lyckas sortera listan, är det viktigt att notera att dess tidskomplexitet gör den mindre effektiv för stora datamängder jämfört med andra sorteringsalgoritmer som Merge Sort eller Quick Sort.

Tidskomplexitet för bubblesortering

arraylistmetoder

Att förstå tidskomplexiteten hos en algoritm är avgörande för att utvärdera dess effektivitet, särskilt när man hanterar stora datamängder. Tidskomplexiteten för Bubble Sort är O(n^2) i värsta fall, där 'n' är antalet element i listan.

Låt oss bryta ner tidskomplexitetsanalysen:

  • Den yttre slingan körs för 'n' iterationer, där 'n' är antalet element i listan.
  • Den inre slingan körs också för 'n' iterationer i värsta fall. Men allt eftersom algoritmen fortskrider, minskar antalet iterationer i den inre slingan, eftersom det största osorterade elementet placeras på sin korrekta position i varje pass.
  • I värsta fall är antalet jämförelser och byten proportionellt mot kvadraten på antalet element i listan, vilket resulterar i O(n^2) tidskomplexitet. Detta gör Bubble Sort ineffektivt för stora datamängder, och mer avancerade sorteringsalgoritmer med bättre tidskomplexitet föredras ofta i verkliga applikationer.

Slutsats

I den här artikeln utforskade vi konceptet med Bubble Sort, en enkel sorteringsalgoritm som upprepade gånger jämför och byter intilliggande element tills hela listan är sorterad. Vi tillhandahöll en Python-implementering av Bubble Sort, körde den med en provlista och analyserade resultatet. Dessutom diskuterade vi tidskomplexiteten för Bubble Sort och lyfte fram dess O(n^2) värsta tänkbara tidskomplexitet och dess konsekvenser för effektiviteten.