일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | |||||
3 | 4 | 5 | 6 | 7 | 8 | 9 |
10 | 11 | 12 | 13 | 14 | 15 | 16 |
17 | 18 | 19 | 20 | 21 | 22 | 23 |
24 | 25 | 26 | 27 | 28 | 29 | 30 |
- AWS
- IT
- 원본과 복사본
- CSS
- appendChild
- APPEND
- 개발툴
- 리커젼
- var
- let
- 코드스테이츠
- 기초공부
- JavaScript
- complexity
- flex기본
- Big-O notation
- 메모이제이션
- AWS기초
- AWS조사
- node.js설치
- css기초
- node.js
- 인터프리터
- 생활코딩
- vscode
- prototype
- scope
- 스코프
- 재귀함수
- 클로저
- Today
- Total
Jveloper
퀵 정렬(Quick Sort Algorithm) 본문
퀵 정렬은 분할 정복(Divide and Conquer) 방식으로 설계된 알고리즘이다.
pivot point라고 기준이 되는 값을 하나 설정하는데, 이 값을 기준으로 작은 값은 왼쪽, 큰 값은 오른쪽으로 옮기는 방식으로 정렬을 진행한다.
이를 반복하여 분할된 배열의 크기가 1이되면 배열이 모두 정렬된것이다.
1. pivot point로 잡을 배열의 값 하나를 정한다. 보통 맨 앞이나 맨 뒤, 혹은 전체 배열 값 중 중간값이나 랜덤값으로 정한다.
2. 분할을 진행하기에 앞서, 비교를 진행하기 위해 가장 왼쪽 배열의 인덱스를 저장하는 left 변수, 가장 오른쪽 배열의 인덱스를 저장한 right 변수를 생성한다.
3. right부터 비교를 진행한다. 비교는 right가 left보다 클 때만 반복하며, 비교한 배열값이 pivot point보다 크면 right를 하나 감소시키고 비교를 반복한다. pivot point보다 작은 배열 값을 찾으면, 반복을 중지한다.
4. 그 다음 left부터 비교를 진행한다. 비교는 right가 left보다 클 때만 반복하며, 비교한 배열값이 pivot point보다 작으면 left를 하나 증가시키고 비교를 반복한다. pivot point보다 큰 배열 값을 찾으면, 반복을 중지한다.
5. left 인덱스의 값과 right 인덱스의 값을 바꿔준다.
6. 3,4,5 과정을 left < right가 만족 할 때까지 반복한다.
7. 위 과정이 끝나면 left의 값과 pivot point를 바꿔준다.
8. 맨 왼쪽부터 left - 1까지, left + 1부터 맨 오른쪽까지로 나눠 퀵 정렬을 반복한다.
퀵 정렬은 분할과 동시에 정렬을 진행하는 알고리즘이다.
각 정렬은 배열의 크기 N만큼 비교하며, 이를 총 분할 깊이인 logN만큼 진행하므로 총 비교횟수는 NlogN, 즉 시간 복잡도는 O(NlogN)이다.
다만 퀵 정렬에는 최악의 경우가 존재하는데, 이는 배열이 이미 정렬이 되어있는 경우이다.
이 경우 분할이 N만큼 일어나므로 최악의 시간복잡도는 O(N^2)이다.
이를 방지하기 위해 앞서 언급했던 전체 배열 값 중 중간값이나 랜덤값으로 pivot point를 정하는 방법을 쓰기도 한다.
최악의 경우 때문에 합병 정렬(Merge Sort)보다 느린 알고리즘이라 생각하기 쉽지만, 발생하기 쉽지 않은 경우이고, 일반적으로 퀵 정렬이 합병 정렬보다 20%이상 빠르다고 한다.
'알고리즘' 카테고리의 다른 글
힙 정렬(Heap Sort Algorithm) (0) | 2019.12.15 |
---|---|
선택 정렬(Selection Sort Algorithm) (0) | 2019.12.15 |
삽입 정렬(Insertion Sort Algorithm) (0) | 2019.12.15 |
버블 정렬(Bubble Sort Algorithm) (0) | 2019.12.15 |
합병 정렬(Merge Sort Algorithm) (0) | 2019.12.15 |