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
- geometry
- database
- implement
- Counting
- java
- bit manipulation
- two pointers
- array
- Matrix
- Class
- SQL
- 코테
- Number Theory
- sorting
- Binary Search
- Data Structure
- 구현
- greedy
- Stack
- 자바
- 파이썬
- Math
- string
- Binary Tree
- dynamic programming
- 코딩테스트
- Tree
- simulation
- hash table
- Method
Archives
- Today
- Total
코린이의 소소한 공부노트
Selection sort 본문
1. Problem
- n개의 정수가 담긴 배열을 오름차순으로 정렬해보자.
- 선택 정렬은 가장 작은 요소를 찾아 자리를 바꾸면서 정렬한다.
- 맨 끝까지의 비교가 1번씩 일어날 때마다 가장 작은 요소가 앞으로 간다.
2. Input
1) int[] arr
3. Output
1) 오름차순으로 정렬된 배열
4. Example
// 예시: (2 3 6 1 5 4)
// 가장 작은 수: 1 -> 1과 2를 바꾼다. -> 1 (3 6 2 5 4)
// 가장 작은 수: 2 -> 2와 3을 바꾼다. -> 1 2 (3 6 5 4)
// 가장 작은 수: 3 -> 바꾸지 않는다. -> 1 2 3 (6 5 4)
// 가장 작은 수: 4 -> 4와 6을 바꾼다. -> 1 2 3 4 (5 6)
// 가장 작은 수: 5 -> 바꾸지 않는다. -> 1 2 3 4 5 6
5. Code
int[] arr = {6, 3, 5, 9, 1, 10, 7, 2, 4, 8}; // 10개의 요소
int min, minIndex = 0, temp = 0;
for(int i=0 ; i<arr.length ; i++) { // 앞에서부터 가장 작은 값을 위치시키려 한다.
min = Integer.MAX_VALUE; // min값은 가장 큰 수로 정의해놓는다.
for(int j=i ; j<arr.length ; j++) // i번째부터 탐색하면서
if(arr[j]<min) { // j번째 요소가 min보다 작다면
min = arr[j]; // min 값을 j번째 요소로 바꾸고
minIndex = j; // 가장 작은 값의 위치를 minIndex에 저장한다.
}
temp = arr[i]; // i번째 값을 임시로 저장한 뒤
arr[i] = arr[minIndex]; // 가장 작은 값을 i번째로 옮기고
arr[minIndex] = temp; // 가장 작은 값이 위치하던 곳에 i번째 값을 옮긴다.
}
// 정렬 확인
for(int i : arr)
System.out.print(i+","); // 1,2,3,4,5,6,7,8,9,10,
- 10개의 요소를 정렬할 때 살펴봐야 하는 총 횟수는 10 + 9 + ... + 1 = 55번의 비교 연산을 해야 한다.
- n개의 요소라면 비교 연산의 총 횟수는 n*(n+1)/2번이다.
- 그러므로 시간 복잡도는 O(n^2)를 따른다.
'Back-End > Algorithm' 카테고리의 다른 글
Insertion sort (0) | 2023.05.19 |
---|---|
Burble sort (0) | 2023.05.19 |
Chained matrix multiplication (0) | 2023.05.11 |
Search Binary Tree (no example) (0) | 2023.03.08 |
Floyd's Algorithm for shortest paths (0) | 2023.03.07 |