일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- 경제
- 독후감
- 자바
- 백준알고리즘
- Java
- algorithmtraining
- 재테크
- 채권
- 서평
- 알고리즘트레이닝
- C
- 지혜를가진흑곰
- 독서
- JavaScript
- 돈
- algorithmStudy
- 알고리즘 공부
- 책알남
- 다독
- 성분
- algorithmTest
- C++
- 프로그래머스 알고리즘 공부
- 알고리즘공부
- 화장품
- 프로그래밍언어
- 자바스크립트
- 주식
- 투자
- 책을알려주는남자
Archives
- Today
- Total
탁월함은 어떻게 나오는가?
[알고리즘] 선택 정렬(Selection Sort) 알고리즘 개념과 원리에 대해 쉽고 빠르게 공부해보자 [C언어] 본문
[Snow-ball]프로그래밍(컴퓨터)/Algorithm
[알고리즘] 선택 정렬(Selection Sort) 알고리즘 개념과 원리에 대해 쉽고 빠르게 공부해보자 [C언어]
Snow-ball 2022. 1. 30. 00:02반응형
알고리즘 훈련중에 제일 먼저 하게되는 연습은 정렬(Sort)알고리즘 이라고 한다. 그 이유는 정렬 알고리즘 만큼 효율성의 차이를 극명하게 보여주는 것이 없다고 한다. 그래서 정렬알고리즘부터 공부를 시작해봐야겠다.
선택 정렬(Selection Sort) 알고리즘 개념
- 제자리 정렬(in-place sorting)의 알고리즘 중 한종류
> 입력 배열(정렬되지 않은 값들) 이외에 다른 추가 메모리를 요구하지 않는 정렬 방법
선택 정렬 알고리즘 동작 원리
- 해당 순서에 원소를 넣을 위치는 이미 정해져 있고, 어떤 원소를 넣을지 선택하는 알고리즘
> 첫 번째 순서에는 첫 번째 위치에 가장 최솟값을 넣는다.
> 두 번째 순서에는 두 번째 위치에 남은 값 중에서 최솟값을 넣는다.
> 그렇게 N번까지 반복 후 N번(마지막)자리에는 제일 큰값을 넣는다.
이미지로 보는 동작 절차
1) [3, 4, 1, 9, 7, 5] 중에서 제일 작은 값을 1번 값으로 교환한다.
> 이미지상 : 1번 값 = 1
2) [1, 4, 3, 9, 7, 5] 중에서 2번 값에 2번째로 작은 값으로 교환한다.
> 이미지상 : 2번 값 = 3
3) 위의 방식의 N번 반복한다.
> 이미지상 결과물 : [1, 3, 4, 5, 7, 9]결과가 나온다.
셀렉 정렬 C언어 코드 :
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
32
33
|
#include <stdio.h>
int main(void) {
int i, j, min, index, temp;
// 10개의 임의의 순서로 들어있는 배열을 생성
int arr[10] = {10, 1, 3, 8, 7, 6, 4, 5, 2, 9};
for (i = 0; i < 10; i++) {
// min 은 최솟값
// min에는 최솟값을 넣기위해 10개의 숫자보다 큰 숫자를 넣어놓는다.
min = 1000;
for (j = i; j < 10; j++) {
// min 보다 배열의 값이 작다면 if문으로 들어간다.
if (min > arr[j]) {
min = arr[j];
index = j;
}
}
// 두개의 원소의 값을 바꾸는 것
// 이것을 일반적으로 스와핑한다 라고 한다.
temp = arr[i];
arr[i] = arr[index];
arr[index] = temp;
}
for (i = 0; i < 10; i++) {
printf("%d ", arr[i]); // 전체 배열값 순회하며 출력
}
return 0;
}
|
cs |
반응형
'[Snow-ball]프로그래밍(컴퓨터) > Algorithm' 카테고리의 다른 글
[algorithm 이론] 자주 접할 수 있는 알고리즘시간 복잡도 정리 (0) | 2022.03.15 |
---|---|
[알고리즘] 퀵 정렬(Quick Sort) 알고리즘 개념과 원리에 대해 쉽고 빠르게 공부해보자 [C언어] (0) | 2022.02.03 |
[알고리즘] 퀵 정렬(Quick Sort) 알고리즘 개념과 원리에 대해 쉽고 빠르게 공부해보자 [C언어] (0) | 2022.02.03 |
[알고리즘] 삽입 정렬(Insertion Sort) 알고리즘 개념과 원리에 대해 쉽고 빠르게 공부해보자 [C언어] (0) | 2022.02.01 |
[알고리즘] 버블 정렬(Bubble Sort) 알고리즘 개념과 원리에 대해 쉽고 빠르게 공부해보자 [C언어] (0) | 2022.01.31 |
Comments