데이터 구조-버블 정렬 알고리즘
버블 정렬은 간단한 정렬 알고리즘입니다. 이 정렬 알고리즘은 인접 요소의 각 쌍을 비교하고 순서가 맞지 않으면 요소를 교체하는 비교 기반 알고리즘입니다. 이 알고리즘은 평균 및 최악의 경우 복잡성이 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 프로그래밍 언어의 버블 정렬 구현에 대해 알아 보려면 여기 를 클릭하십시오 .