- Today
- Total
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- 감성에세이
- coding test
- 프로그래머스
- sort
- swift split
- 자료구조
- Design Pattern
- 스위프트
- swift 알고리즘
- 정렬 알고리즘
- 디자인 패턴
- swift 코딩테스트
- 디자인패턴
- 코딩테스트
- datastructure
- 알고리즘
- 다트
- 프로그래머스 swift
- 정렬
- 스위프트디자인패턴
- dart
- Algorithm
- 프로그래머스 레벨2
- programmer
- 코테
- 정렬알고리즘
- swift
- 프로그래머스 level1
- programmers
- rxswift
Bill Kim's Life...
[Algorithm] Sorting Comparison : 정렬 알고리즘 종류와 특징, 그리고 효율성 본문
[Algorithm] Sorting Comparison : 정렬 알고리즘 종류와 특징, 그리고 효율성
billnjoyce 2020. 6. 24. 15:08알고리즘에서의 정렬 알고리즘의 종류와 그 특징에 대하여 살펴봅니다.
#. 구독 대상
- 컴퓨터 및 소프트웨어 공학과 관련자
- 소프트웨어 관련 종사자
- 기타 컴퓨터 공학에 관심이 있으신 분
- 알고리즘의 개념을 잡고 싶으신 분
- 기타 소프트웨어 개발과 지식에 관심이 있으신 모든 분들
Introduction
본 글에서는 컴퓨터 과학에서 사용되는 정렬 알고리즘들에 대한 큰 특징들을 살펴보며 각 알고리즘 별로 공간 및 시간 복잡도에 대해서 서로 비교를 해봅니다.
Sorting Algorithms
정렬 알고리즘은 크게 보면 형태나 방법에 따라 아래와 같이 분류될 수 있습니다.
그렇다면 대표적인 정렬 알고리즘의 대해서 하나씩 살펴보도록 하겠습니다.
버블정렬(Bubble Sort)
선택정렬(Selection Sort)
삽입정렬(Insertion Sort)
퀵 정렬(Quick Sort)
병합정렬(Merge Sort)
힙 정렬(Heap Sort)
쉘 정렬(Shell Sort)
기수정렬(Radix Sort)
카운팅정렬(Counting Sort)
공간 복잡도(Space Complexity)
지금까지 살펴본 정렬 알고리즘들의 공간 복잡도를 다시 한번 비교해보겠습니다.
시간 복잡도(Time Complexity)
마찬가지로 지금까지 살펴본 정렬 알고리즘들의 시간 복잡도를 다시 한번 비교해보겠습니다.
이상으로 지금까지 정렬 알고리즘의 종류와 그 특징에 대하여 설명하였습니다.
감사합니다.
[참고 자료(References)]
[1] 정렬 알고리즘 비교 : https://ratsgo.github.io/data%20structure&algorithm/2017/10/19/sort/
[2] [ 정렬 ] 정렬별 장단점 및 시간복잡도 : https://yabmoons.tistory.com/250
[3] [C언어] 여러가지 정렬 속도 비교(정렬의 시간복잡도) : https://coding-factory.tistory.com/138
[4] 정렬 알고리즘의 종류 및 속도 비교 : https://moyaria.tistory.com/1399
[5] 정렬 알고리즘(Sorting Algorithm) | 종류 및 속도 비교 : https://m.blog.naver.com/go2604/221824669394
[6] 정렬 알고리즘의 비교 : https://wonjayk.tistory.com/225
[7] 정렬 알고리즘 비교 : https://defacto-standard.tistory.com/37
[8] 정렬 알고리즘 (Sorting Algorithm) : https://2heedu.tistory.com/160
[9] 정렬 알고리즘 정리 : https://medium.com/@wooder2050/정렬-알고리즘-정리-54349222f432
[10] 제 2 강. 알고리즘과 알고리즘의 성능 : http://dblab.duksung.ac.kr/ds/pdf/Chap02.pdf
[11] [Algorithm] Time Complexity : https://velog.io/@junyong92/TIL-Time-Complexity
[12] [알고리즘] 점근적 표기법 : https://satisfactoryplace.tistory.com/70
'CS(컴퓨터 과학) > Algorithm' 카테고리의 다른 글
[Algorithm] Big O Notation(빅 오 표기법) : 대표적인 점근 표기법, 알고리즘 공간 및 시간 복잡도 등에서 활용 (0) | 2020.06.24 |
---|---|
[Algorithm] Counting Sort(계수 정렬) : 각 숫자의 카운팅 배열을 활용하여 정렬하는 알고리즘 (0) | 2020.06.19 |
[Algorithm] Radix Sort(기수 정렬) : 자릿수를 비교하여 정렬하는 알고리즘 (0) | 2020.06.19 |
[Algorithm] Shell Sort(쉘 정렬) : 삽입 정렬을 보완한 정렬 알고리즘 (0) | 2020.06.19 |
[Algorithm] Heap Sort(힙 정렬) : 힙 트리를 활용한 정렬 알고리즘 (0) | 2020.06.19 |