728x90
정렬이란 데이터를 특정한 기준에 따라 순서대로 나열하는 것을 말한다.
일반적으로 문제 상황에 따라서 적절한 정렬 알고리즘이 공식처럼 사용
선택 정렬
처리되지 않은 데이터 중에서 가장 작은 데이터를 선택해 맨 앞에 있는 데이터와 바꾸는 것을 반복합니다.
array = [7, 5, 9, 0, 3, 1, 6, 2, 4, 8]
for i in range(len(array)):
min_index = i # 가장 작은 원소의 인덱스
for j in range(i + 1, len(array)):
if array[min_index] > array[j]:
min_index = j
array[i], array[min_index] = array[min_index], array[i] #스와프
print(array)
선택 정렬의 시간 복잡도
선택 정렬은 N번 만큼 가장 작은 수를 찾아서 맨 앞으로 보내야 합니다.
구현 방식에 따라서 사소한 오차는 있을 수 있지만 전체 연산은
N + ( N - 1 ) + ( N - 2 ) + ... + 2
이는 (N^2 + N - 2) / 2 로 표현할 수 있는데 빅오표기법에 따라 O(N^2)이라고 작성합니다.
728x90
'코딩테스트를 위한 자료구조 알고리즘' 카테고리의 다른 글
퀵 정렬 (0) | 2021.10.26 |
---|---|
삽입 정렬 알고리즘 (0) | 2021.10.26 |
DFS & BFS (0) | 2021.10.25 |
구현 (0) | 2021.10.25 |
그리디 알고리즘 (0) | 2021.10.25 |