Java/Do it 알고리즘 코딩테스트 핵심이론 강의
알고리즘 코딩테스트 핵심이론 강의 - 선택 정렬
냠냠쿠
2023. 8. 9. 11:52
728x90
https://www.youtube.com/watch?v=lM6BFazUHjA&list=PLFgS-xIWwNVX-zm4m6suWC9d7Ua9z7fuT&index=16
📌 정렬 알고리즘
정렬 알고리즘정의
버블 (bubble) | 데이터의 인접 요소끼리 비교하고 swap 연산을 수행하여 정렬 |
선택 (selection) | 대상에서 가장 크거나 작은 데이터를 찾아가 선택을 반복하며 정렬 |
삽입 (insertion) | 대상을 선택해 정렬된 영역에서 선택 데이터의 적절한 위치를 찾아 삽입하면서 정렬 |
퀵 (quick) | pivot 값을 선정해 해당 값을 기준으로 정렬 |
병합 (merge) | 이미 정렬된 부분 집합들을 효율적으로 병합해 전체를 정렬하는 |
기수 (radix) | 데이터의 자릿수를 바탕으로 비교해 데이터를 정렬 |
📌 선택 정렬
- 정렬되지 않은 데이터에서 최대나 최소 데이터가 나열된 순으로 찾아가며 선택
- 구현 방법이 불편
시간 복잡도가 O(n²)으로 속도가 느린 편
◾ 선택 정렬 이론
- 최솟값 또는 최댓값을 찾고 남은 정렬부분의 가장 앞에 있는 데이터와 swap 하는 것이 선택 정렬의 핵심
출처 : https://hongcoding.tistory.com/181
◾ 선택 정렬 과정
- 남은 정렬 부분에서 최솟값 또는 최댓값을 찾는다.
- 남은 정렬 부분에서 가장 앞에 있는 데이터와 선택된 데이터를 swap한다.
- 가장 앞에 있는 데이터의 위치를 변경해 (index ++) 남은 정렬 부분의 범위를 축소한다.
- 전체 데이터 크기만큼 index가 커질 때 까지 (남은 정렬부분이 없을 때 까지) 반복
728x90