데이터 구조-버블 정렬 알고리즘

버블 정렬은 간단한 정렬 알고리즘입니다. 이 정렬 알고리즘은 인접 요소의 각 쌍을 비교하고 순서가 맞지 않으면 요소를 교체하는 비교 기반 알고리즘입니다. 이 알고리즘은 평균 및 최악의 경우 복잡성이 0 (n 2 ) 이므로 대규모 데이터 세트에는 적합하지 않습니다 .n 항목 수입니다.

버블 정렬은 어떻게 작동합니까?

예를 들어 정렬되지 않은 배열을 사용합니다. 버블 정렬은 Ο (n 2 ) 시간이 걸리므로 짧고 정확하게 유지하고 있습니다.

버블 정렬은 처음 두 요소로 시작하여 어느 것이 더 큰지 확인하기 위해 비교합니다.

이 경우 값 33은 14보다 크므로 이미 정렬 된 위치에 있습니다. 다음으로 33과 27을 비교합니다.

27이 33보다 작으며이 두 값을 바꿔야합니다.

새 배열은 다음과 같아야합니다.

다음으로 33과 35를 비교합니다. 둘 다 이미 정렬 된 위치에 있습니다.

그런 다음 다음 두 값인 35와 10으로 이동합니다.

그러면 10이 35보다 작다는 것을 압니다. 따라서 정렬되지 않습니다.

우리는 이러한 가치를 교환합니다. 배열의 끝에 도달했습니다. 한 번의 반복 후 배열은 다음과 같아야합니다.

정확히 말하면, 우리는 이제 각 반복 후에 배열이 어떻게 생겼는지 보여주고 있습니다. 두 번째 반복 후에는 다음과 같이 보일 것입니다.

각 반복 후에 적어도 하나의 값이 끝에서 이동합니다.

그리고 교체가 필요하지 않은 경우 버블 정렬은 배열이 완전히 정렬되었음을 학습합니다.

이제 버블 정렬의 몇 가지 실용적인 측면을 살펴 보겠습니다.

연산

우리는 추정하다 list 배열입니다 n집단. 우리는 또한swap 함수는 주어진 배열 요소의 값을 바꿉니다.

begin BubbleSort(list)

   for all elements of list
      if list[i] > list[i+1]
         swap(list[i], list[i+1])
      end if
   end for
   
   return list
   
end BubbleSort

의사 코드

우리는 전체 배열이 오름차순으로 완전히 정렬되지 않는 한 Bubble Sort가 각 배열 요소 쌍을 비교하는 알고리즘을 관찰합니다. 이로 인해 모든 요소가 이미 오름차순으로 배열되어 더 이상 스왑이 필요하지 않은 경우와 같은 몇 가지 복잡성 문제가 발생할 수 있습니다.

문제를 완화하기 위해 플래그 변수 하나를 사용합니다. swapped스왑이 발생했는지 확인하는 데 도움이됩니다. 스왑이 발생하지 않은 경우, 즉 배열에 더 이상 정렬 처리가 필요하지 않으면 루프에서 나옵니다.

BubbleSort 알고리즘의 의사 코드는 다음과 같이 작성할 수 있습니다.

procedure bubbleSort( list : array of items )

   loop = list.count;
   
   for i = 0 to loop-1 do:
      swapped = false
		
      for j = 0 to loop-1 do:
      
         /* compare the adjacent elements */   
         if list[j] > list[j+1] then
            /* swap them */
            swap( list[j], list[j+1] )		 
            swapped = true
         end if
         
      end for
      
      /*if no number was swapped that means 
      array is sorted now, break the loop.*/
      
      if(not swapped) then
         break
      end if
      
   end for
   
end procedure return list

이행

원래 알고리즘과 즉석 의사 코드에서 다루지 않은 또 하나의 문제는 모든 반복 후에 가장 높은 값이 배열의 끝에 정착된다는 것입니다. 따라서 다음 반복은 이미 정렬 된 요소를 포함 할 필요가 없습니다. 이를 위해 구현에서 이미 정렬 된 값을 피하기 위해 내부 루프를 제한합니다.

C 프로그래밍 언어의 버블 정렬 구현에 대해 알아 보려면 여기 를 클릭하십시오 .