📌 정렬 알고리즘 종류
정렬 알고리즘 | 정의 |
버블 (bubble) | 데이터의 인접 요소끼리 비교하고, swap 연산을 수행하며 정렬하는 방식 |
선택 (selection) | 대상에서 가장 크거나 작은 데이터를 찾아가 선택을 반복하면서 정렬하는 방식 |
삽입 (insertion) | 대상을 선택해 정렬된 영역에서 선택 데이터의 적절한 위치를 찾아 삽입하면서 정렬하는 방식 |
퀵 (quick) | pivot 값을 선정해 해당 값을 기준으로 정렬하는 방식 |
병합 (merge) | 이미 정렬된 부분 집합들을 효율적으로 병합해 전체를 정렬하는 방식 |
기수 (radix) | 데이터의 자릿수를 바탕으로 비교해 데이터를 정렬하는 방식 |
📌 선택 정렬이란?
- 정렬되지 않은 데이터들에 대해 가장 크거나 작은 데이터를 찾아가 선택을 반복하면서 정렬하는 방식
- 시간 복잡도 : O(n^2) → 느린편 (많이 사용되지 않는 방법)
📌 선택 정렬 과정
1. 남은 정렬 부분에서 최솟값 또는 최댓값을 찾음
2. 남은 정렬 부분에서 가장 앞에 있는 데이터와 선택된 데이터를 swap
3. 가장 앞에 있는 데이터의 위치를 변경해(index ++) 남은 정렬 부분의 범위를 축소
4. 전체 데이터 크기만큼 index가 커질 때까지, 즉 남은 정렬 부분이 없을 때까지 반복
<Example>
29, 16, 9, 17, 21
➡️ 최솟값 9를 맨 앞의 29와 swap
9, 16, 29, 17, 21
➡️ 최솟값 16을 두 번째와 swap 해야하지만, 이미 두 번째에 위치하므로 넘어감
9, 16, 29, 17, 21
➡️ 최솟값 17을 세 번째와 swap
9, 16, 17, 29, 21
➡️ 최솟값 21을 네 번째와 swap
9, 16, 17, 21, 29
➡️ 정렬 완료!
📌 선택 정렬 장점
- 단순성
- swap의 횟수가 최소화
📌 선택 정렬 단점
- 시간 복잡도가 O(n^2)로 매우 느린편
- 부분적으로 정렬되었는지 고려하지 않고 동일한 수의 swap이 발생함
- 잘 사용되지 않는다
✅ 다음 게시글에서 예제 문제로 더 자세히 이해해보도록 하겠습니다!
[JAVA][Baekjoon] 1427번 소트인사이드
https://www.acmicpc.net/problem/1427 📌 접근 방식선택 정렬을 사용해 풀어보았습니다. [알고리즘] 선택 정렬(Selectio Sort)이란?📌 정렬 알고리즘 종류정렬 알고리즘정의버블 (bubble)데이터의 인접 요소
nyeroni.tistory.com
![](https://t1.daumcdn.net/keditor/emoticon/friends1/large/020.gif)
Reference
선택 정렬(Selection Sort)의 정의, 장단점 및 타정렬과 비교
정렬 알고리즘은 컴퓨터 과학의 기본이며 데이터를 정리하는 데 중요한 역할을 합니다. 이 글에서는 특정 순서로 요소를 정렬하는 간단하고 직관적인 방법인 선택 정렬의 내부 작동 방식, 시간
111.dreamingnote.com
'CS > 알고리즘' 카테고리의 다른 글
[알고리즘] 기수 정렬(Radix Sort)이란? (0) | 2025.01.03 |
---|---|
[알고리즘] 병합 정렬(Merge Sort)이란? (0) | 2025.01.03 |
[알고리즘] 퀵 정렬(Quick Sort)이란? (1) | 2025.01.02 |
[알고리즘] 삽입 정렬(Insertion Sort)이란? (0) | 2025.01.02 |
[알고리즘] 버블 정렬(Bubble Sort)이란? (0) | 2024.05.12 |