정렬 Sort
1. 기본 개념
2. 비교 기반 알고리즘
1) 선택 정렬
2) 버블 정렬
3) 삽입 정렬
4) 셸 정렬
1. 기본 개념
1) “정렬(Sort)”이란?
- 주어진 데이터를 값의 크기 순서에 따라 재배치 하는 것
- 대표 : 오름차순(Ascending), 내림차순(Descending)
2) 정렬 구분
- 기준 : 정렬이 수행되는 시점에 데이터가 어디에 저장되어 있는가?
✅ 내부 정렬 | 컴퓨터 내에 있는 주기억 장치에 데이터가 있음 |
전체 데이터 위치 : 주기억장치에 저장 → 정렬 수행 |
외부 정렬 | 주기억 장치 밖에 데이터가 있음 (주기억장치에 모든 데이터를 저장 할 수 없는 경우) |
전체 데이터 위치 : 보조 기억장치 → 필요한 일부 데이터만 반복적으로 주기억장치로 옮겨 → 정렬 수행 |
3) 내부 정렬의 정렬 방식
📍point - 몇 번 비교 했는가 vs 몇 번 이동했는가!
- 비교 기반 알고리즘
- 어떤 값을 비교할 때, 직접 적으로 비교하는 방식 (1은 2보다 작다. 2는 1보다 크다.)
- 성능 기준 : 키 값의 비교 횟수
- 종류
- 선택정렬, 버블 정렬, 삽입정렬, 셸 정렬 ← O(n²) : 가장 기본 성능
- 퀵 정렬, 합병 정렬, 힙 정렬 ← O(nlogn)
- 데이터 분포 기반 알고리즘
- 데이터의 분포 정보를 활용하여 정렬 수행
- 성능 기준 : 데이터의 이동 횟수
- 정렬 전 데이터의 분포 정보가 중요함
- 계수 정렬, 기수 정렬, 버킷 정렬 ← 제한 조건 부합 시 : O(n)
4) 안정적 정렬 (Stable Sort)
- 동일한 값을 갖는 데이터가 여러 개일 경우, 정렬 전의 상대적 위치가 정렬 후에도 그대로 유지되는 정렬
입력 데이터 | [5, 1, 4, 3, 6, 2, 4] |
|
정렬 데이터 | [1, 2, 3, 4, 4, 5, 6] | 안정 정렬 |
[1, 2, 3, 4, 4, 5, 6] | 불안정적 정렬 |
- 안정적 정렬 : 버블 정렬, 삽입 정렬
- 불안정적 정렬 : 선택 정렬, 셸 정렬
5) 제자리 정렬(In-place Sort)
- 입력 배열 이외에 별로도 필요한 저장 공간이 상수개를 넘지 않는 정렬
- 입력되는 데이터의 크기 n이 증가 하더라도, 저장공간이 추가되지 않음. 저장 공간은 고정.
- 저장 공간이 추가되면? ‘제자리 정렬이 아니다.
[정렬별 특징]
선택 정렬 | 버블 정렬 | 삽입 정렬 | 셸 정렬 |
O(n2) | O(n2) | O(n2) | O(n2) |
제자리 | 제자리 | 제자리 | 제자리 |
불안정 | 안정적 | 안정적 | 불안정 |
반응형
'D.evelop [CS] > Algorithm' 카테고리의 다른 글
[알고리즘 이론] 정렬 Sort - 2-2 비교 기반 알고리즘 (버블 정렬) (0) | 2024.04.22 |
---|---|
[알고리즘 이론] 정렬 Sort - 2-1. 비교 기반 알고리즘 (선택 정렬) (0) | 2024.04.18 |
[Algorithm 030] JS - 자연수 뒤집어 배열로 만들기 (Level 01) (0) | 2021.12.02 |
[Algorithm 029] JS - 정수 내림차순으로 배치하기 (Level 01) (0) | 2021.11.22 |
[Algorithm 028] JS - 최대공약수와 최소공배수 (Level 01) (0) | 2021.11.16 |
댓글