DAA-버블 정렬

버블 정렬은 필요한 경우 인접한 요소를 반복적으로 교환하여 작동하는 기본 정렬 알고리즘입니다. 교환이 필요하지 않으면 파일이 정렬됩니다.

이것은 모든 정렬 알고리즘 중에서 가장 간단한 기술입니다.

Algorithm: Sequential-Bubble-Sort (A) 
fori← 1 to length [A] do 
for j ← length [A] down-to i +1 do 
   if A[A] < A[j - 1] then 
      Exchange A[j] ↔ A[j-1]

이행

voidbubbleSort(int numbers[], intarray_size) { 
   inti, j, temp; 
   for (i = (array_size - 1); i >= 0; i--) 
   for (j = 1; j <= i; j++) 
      if (numbers[j - 1] > numbers[j]) { 
         temp = numbers[j-1]; 
         numbers[j - 1] = numbers[j]; 
         numbers[j] = temp; 
      } 
}

분석

여기서 비교 횟수는 다음과 같습니다.

1 + 2 + 3 +...+ (n - 1) = n(n - 1)/2 = O(n2)

분명히 그래프는 n2 거품 종류의 본질.

이 알고리즘에서 비교 횟수는 데이터 세트, 즉 제공된 입력 요소가 정렬 된 순서인지 역순인지 또는 무작위인지 여부와 관계가 없습니다.

메모리 요구 사항

위에 언급 된 알고리즘에서 버블 정렬에 추가 메모리가 필요하지 않음이 분명합니다.

Unsorted list:

5 2 1 4 7 6

1 일의 반복 :

5 > 2 swap

2 5 1 4 7 6

5 > 1 swap

2 1 5 4 7 6

5 > 4 swap

2 1 4 5 7 6

5 > 3 swap

2 1 4 5 7 6

5 < 7 no swap

2 1 4 5 7 6

7 > 6 swap

2 1 4 5 6 7

2 반복 :

2 > 1 swap

1 2 4 5 6 7

2 < 4 no swap

1 2 4 5 6 7

4 > 3 swap

1 2 4 5 6 7

4 < 5 no swap

1 2 4 5 6 7

5 < 6 no swap

1 2 4 5 6 7

3 번째 , 4 번째 , 5 번째 및 6 번째 반복 에는 변경이 없습니다 .

드디어,

the sorted list is

1 2 4 5 6 7