Taaewoo
Data Engineering Blog
Taaewoo
전체 방문자
오늘
어제
  • 분류 전체보기 (67)
    • Computer Science (16)
      • Algorithm (6)
      • OS (1)
      • Java (2)
      • C++ (6)
      • Python (1)
    • Hadoop Ecosystem (27)
      • Hadoop (6)
      • Spark (5)
      • NiFi (6)
      • Hive (9)
      • Kafka (1)
    • BigData Engineering (14)
      • Jupyter (1)
      • Docker (3)
      • CDH (3)
      • Riot Data Pipeline (7)
    • Back-end 개발 (0)
      • Spring (0)
    • Algorithm 문제 풀이 (9)
      • 백준 (5)
      • LeetCode (4)
    • Conference (1)
      • LINE DEVELOPER DAY 2021 (1)
      • if(kakao) 2021 (0)

블로그 메뉴

  • 홈
  • 태그
  • 방명록

공지사항

인기 글

태그

  • 코딩
  • sort
  • metastore
  • Coding
  • hadoop
  • spark
  • BigData
  • kafka
  • hdfs
  • algorithm
  • CS
  • 정렬
  • 빅데이터
  • java
  • C++
  • 프로그래밍
  • NiFi
  • Hive
  • docker
  • 알고리즘

최근 댓글

최근 글

티스토리

hELLO · Designed By 정상우.
Taaewoo

Data Engineering Blog

[Algorithm] Sort #3 - 삽입 정렬 Insertion Sort
Computer Science/Algorithm

[Algorithm] Sort #3 - 삽입 정렬 Insertion Sort

2021. 1. 4. 23:17

삽입 정렬이란?

 기준 숫자를 정렬된 리스트에 삽입해 정렬하는 알고리즘

 

시간 복잡도

최상 : \( O(n) \)

최악 : \( O(n^2) \)

 

관련 글

[Algorithm] Sort #1 - 버블 정렬 Bubble Sort

[Algorithm] Sort #2 - 선택 정렬 Selection Sort

[Algorithm] Sort #4 - 병합 정렬 Merge Sort

[Algorithm] Sort #5 - 힙 정렬 Heap Sort

[Algorithm] Sort #6 - 퀵 정렬 Quick Sort

 


 

 정렬 알고리즘에 있어 기본인 버블 정렬, 선택 정렬 다음으로는 삽입 정렬입니다.

 

알고리즘

 삽입 정렬의 알고리즘은 다음과 같습니다.

  1. 기준 값을 정한다..
  2. 기준 값을 정렬된 원소들과 하나씩 비교해 알맞은 자리에 위치시킨다.
  3. 1,2의 과정을 n-1번 진행한다.

 

삽입 정렬 예시

{ 9, 1, 7, 5, 2} 순서대로 원소가 존재한다고 가정했을 때 삽입 정렬의 예시는 다음과 같습니다.

 

 

 삽입 정렬도 선택 정렬과 같이 버블 정렬에 비해 과정이 단순해 보이지만 위 그림에서는 생략된 부분이 있습니다. 생략된 것은 바로 삽입 과정에서 정렬된 원소들과의 비교 과정입니다. 기준 값을 정렬된 원소에 넣기 위해서는 정렬된 원소의 맨 뒤부터 순차적으로 비교해야 합니다. 비교 과정에서 기준 값보다 작은 숫자를 찾았다면 해당 원소 바로 뒤에 위치시킵니다.

 

시간 복잡도 계산

 삽입 정렬의 시간 복잡도는 최악, 최상의 경우가 다릅니다. 

 

최상

 최상의 경우라면 이미 모든 원소들이 정렬되어 있는 상태입니다. 이 때는 기준 값과 정렬된 리스트 중 오직 마지막 원소만 비교할 뿐만 아니라 알맞은 자리에 위치시키는 과정 또한 생략되기 때문에 총 n-1번만 진행됩니다. 그래서 시간 복잡도는 \( O(n) \)입니다.

 

최악

 하지만 최악의 경우라면 모든 원소들이 정렬의 역순으로 있는 상태입니다. 이 때는 기준 값 하나를 위치시킬 때마다 1,2, ... n-2, n-1번 비교해야 합니다. 이 과정을 n-1번 하기 때문에 시간 복잡도는 \( O(n^2) \)입니다.

 

 

 최악의 경우 이전 글에서 설명한 버블 정렬, 선택 정렬과 비슷한 수준이지만 최상의 경우에 가까워질수록 삽입 정렬이 두 정렬보다 매우 빠르다고 볼 수 있습니다.

 

C++ Code

#include <iostream>
#include <vector>
#include <algorithm>

using namespace std;

int main()
{
    vector<int> arr = {9,1,7,5,2};
    vector<int> sorted_arr;
    sorted_arr.push_back(arr[0]);
    
    for(int i=1; i<arr.size(); i++){
        int pos = 0;
    
        for(int j=sorted_arr.size()-1; j>=0; j--){
            if(sorted_arr[j] < arr[i]){
                pos = j+1;
                break;
            }
        }
        
        sorted_arr.insert(sorted_arr.begin()+pos, arr[i]);
    }
    
    
    for(int i=0; i<sorted_arr.size(); i++)
        cout << sorted_arr[i];
}
저작자표시 비영리

'Computer Science > Algorithm' 카테고리의 다른 글

[Algorithm] Sort #6 - 퀵 정렬 Quick Sort  (0) 2021.01.16
[Algorithm] Sort #5 - 힙 정렬 Heap Sort  (0) 2021.01.09
[Algorithm] Sort #4 - 병합 정렬 Merge Sort  (0) 2021.01.08
[Algorithm] Sort #2 - 선택 정렬 Selection Sort  (0) 2021.01.02
[Algorithm] Sort #1 - 버블 정렬 Bubble Sort  (0) 2020.12.29
    'Computer Science/Algorithm' 카테고리의 다른 글
    • [Algorithm] Sort #5 - 힙 정렬 Heap Sort
    • [Algorithm] Sort #4 - 병합 정렬 Merge Sort
    • [Algorithm] Sort #2 - 선택 정렬 Selection Sort
    • [Algorithm] Sort #1 - 버블 정렬 Bubble Sort
    Taaewoo
    Taaewoo

    티스토리툴바