logo

Bubble Sort в Python

Bubble Sort е прост алгоритъм за сортиране, който многократно преминава през списъка, сравнява съседни елементи и ги разменя, ако са в грешен ред. Нарича се „Сортиране с мехурчета“, защото по-малките елементи „балонират“ в горната част на списъка. Въпреки че не е най-ефективният алгоритъм за сортиране, той е лесен за разбиране и прилагане, което го прави добра отправна точка за изучаване на алгоритмите за сортиране. В тази статия ще разгледаме концепцията за Bubble Sort, ще предоставим реализация на Python с изход и ще обсъдим времевата сложност на алгоритъма.

Разбиране на Bubble Sort

Основната идея зад Bubble Sort е списъкът да се итерира многократно, като се сравняват съседни елементи и се разменят, ако не са в ред. Процесът продължава, докато не са необходими повече суапове, което показва, че списъкът вече е сортиран. Алгоритъмът получава името си от начина, по който по-малките елементи постепенно се придвижват към горната част на списъка, подобно на мехурчета, издигащи се на повърхността.

Нека разбием стъпките на алгоритъма за Bubble Sort:

  1. Преминаване през списъка: Започнете от началото на списъка и сравнете всяка двойка съседни елементи.
  2. Сравнете и разменете: Ако елементите са в грешен ред, разменете ги. Това гарантира, че по-големият елемент се „издухва“, а по-малкият се движи надолу.
  3. Продължаване на повторението: Повторете процеса за всяка двойка съседни елементи, докато се стигне до края на списъка.
  4. Повторете, докато не бъде сортиран: Продължавайте да обикаляте списъка, докато не са необходими повече суапове. В този момент списъкът е сортиран.

Въпреки че Bubble Sort е лесен за разбиране, той не е най-ефективният алгоритъм за сортиране, особено за големи набори от данни. Времевата му сложност е O(n^2) в най-лошия случай, където 'n' е броят на елементите в списъка. Тази квадратична времева сложност го прави по-малко подходящ за големи масиви от данни в сравнение с по-усъвършенстваните алгоритми за сортиране.

Внедряване на Bubble Sort в Python

Сега нека внедрим Bubble Sort в Python и да наблюдаваме поведението му с примерен списък:

 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) 

В тази реализация функцията bubble_sort приема списък (arr) като свой параметър и го сортира на място. Вложеният цикъл сравнява съседни елементи и ги разменя, ако са в грешен ред. Външният цикъл гарантира, че процесът се повтаря, докато целият списък бъде сортиран.

java връзка mysql

Изход и обяснение

Нека изпълним предоставения код на Python с примерния списък и наблюдаваме резултата:

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

Тук оригиналният списък [64, 34, 25, 12, 22, 11, 90] е успешно сортиран с помощта на алгоритъма за сортиране с мехурчета, което води до сортирания списък [11, 12, 22, 25, 34, 64, 90].

Алгоритъмът преминава през списъка няколко пъти, сравнявайки и разменяйки елементи, докато целият списък бъде сортиран. При всяко преминаване най-големият несортиран елемент се „издига“ до правилната си позиция. Този процес продължава, докато не са необходими повече суапове, което показва, че списъкът е напълно сортиран.

Въпреки че Bubble Sort успешно сортира списъка, важно е да се отбележи, че неговата времева сложност го прави по-малко ефективен за големи набори от данни в сравнение с други алгоритми за сортиране като Merge Sort или Quick Sort.

Времева сложност на балонно сортиране

Разбирането на времевата сложност на даден алгоритъм е от решаващо значение за оценката на неговата ефективност, особено когато се работи с големи масиви от данни. Времевата сложност на Bubble Sort е O(n^2) в най-лошия случай, където 'n' е броят на елементите в списъка.

Нека разбием анализа на времевата сложност:

  • Външният цикъл се изпълнява за 'n' итерации, където 'n' е броят на елементите в списъка.
  • Вътрешният цикъл също работи за 'n' итерации в най-лошия случай. С напредването на алгоритъма обаче броят на итерациите във вътрешния цикъл намалява, тъй като най-големият несортиран елемент се поставя на правилната си позиция при всяко преминаване.
  • В най-лошия случай броят на сравненията и размените е пропорционален на квадрата на броя на елементите в списъка, което води до времева сложност O(n^2). Това прави Bubble Sort неефективно за големи масиви от данни и по-усъвършенстваните алгоритми за сортиране с по-добра времева сложност често се предпочитат в приложения от реалния свят.

Заключение

В тази статия изследвахме концепцията за Bubble Sort, прост алгоритъм за сортиране, който многократно сравнява и разменя съседни елементи, докато целият списък бъде сортиран. Предоставихме реализация на Python на Bubble Sort, пуснахме я с примерен списък и анализирахме изхода. Освен това обсъдихме времевата сложност на Bubble Sort, подчертавайки нейната O(n^2) времева сложност в най-лошия случай и нейните последици за ефективността.