Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 | 31 |
Tags
- oracle
- 파이썬
- URI 원칙
- conda remove
- h2 데이타베이스
- 자바 열거형
- GIT
- 셀레니움
- streamlit
- 스프링 부트3
- 스프링 부트
- 사이킷런 회귀
- 차원증가
- 프로그래머스
- 머신러닝
- 오라클
- Java
- openai
- 컬렉션 인터페이스
- 완주하지못한선수
- 자바 로그 레벨
- 사이킷런
- Selenium
- Python
- 쓰레드 풀
- 컬렉션 프레임웍
- WinError5
- 알고리즘
- REST API
- db
Archives
- Today
- Total
노트 :
선택 정렬 (Selection Sort) 본문
선택 정렬은 정렬되지 않은 배열에서 반복적으로 최소값을 가지는 원소(오름차순 정렬의 경우)를 찾아 배열의 맨 앞자리에 높음으로써 정렬하는 방식이다. 선택 정렬은 원 배열을 두 개의 서브 배열로 나눈다.
1) 이미 정렬되어 있는 서브 배열
2) 정렬되어 있지 않은 나머지 서브 배열. 선택 정렬을 순회하는 매 차수마다 최소값을 가지는 원소가 해당 서브 배열에서 선택되어 이미 정렬되어 있는 1번 서브 배열로 옮겨진다.
공간복잡도: O(n)
시간복잡도: O(n^2)
코드>
def selection_sort(array):
for idx in range(len(array)):
min_idx = idx
for j in range(idx+1, len(array)):
if array[j] < array[min_idx]:
min_idx = j
(array[idx], array[min_idx]) = (array[min_idx], array[idx])
return(array)
실행결과>
출처: https://www.geeksforgeeks.org/python-program-for-selection-sort/
'Algorithm' 카테고리의 다른 글
버블 정렬 (Bubble Sort) (1) | 2023.05.18 |
---|---|
[알고리즘] 알고리즘 설계 기법 (1) | 2023.02.02 |
[프로그래머스] 완주하지 못한 선수2 (0) | 2022.10.03 |
[프로그래머스] 완주하지 못한 선수 (0) | 2022.09.30 |
[프로그래머스] 문자열 다루기 기본 (0) | 2022.09.28 |