ABOUT ME

-

Today
-
Yesterday
-
Total
-
  • [알고리즘] 삽입 정렬(Insertion Sort)
    알고리즘 & 자료구조/알고리즘 2021. 3. 6. 17:32

    아래의 숫자들을 오름차순으로 정렬한다고 생각해보자

     

    1  10  5  8  7  6  4  3  2  9

     

    버블 정렬과 선택정렬을 사용 할 수도 있지만, 삽입 정렬을 사용하면 특정상황에 따라서는 보다 효율적으로 정렬할 수 있다.

     

    다른 정렬들은 무조건 위치를 바꾸는 방식이였지만, 삽입정렬의 다른점은 '필요할 때만' 위치를 바꾼다는 것이다.

     

     

     

    예를들어 보자,

    아래와 같은 숫자들을 오름차순 정렬한다고 했을때, 삽입정렬은

     

    1  10  5  8  7  6  4  3  2  9

     

     바로 옆의 10과 대소를 비교한다.

     

    10은 1의 앞 혹은 지금 현재 자리에 있을 수 있는데, 오름차순이기때문에 현재 위치를 그대로 유지하면 된다.

     

    그다음 10 과 5를 비교해보면,

    5가 더 작기때문에 10과 5의 자리를 바꿔준다.

     

    조금 더 쉽게 생각하면 빈칸이 있다고 생각을 해보면 된다.

     

    1  _ 10 _  5  8  7  6  4  3  2  9

     

    5가 들어갈수 있는 부분은 _ 칸으로 나타있는데 10보다 크다면 오른쪽 _ 에 위치하고 그렇지 않다면 오른쪽 _ 에 위치해야한다.

    5는 10보다 작으므로, 왼쪽에 위치한다.

     

    1  5 10 _  8  7  6  4  3  2  9

     

    이러한 과정을 반복하고 나면,

     

    1 2 3 4 5 6 7 8 9 10

     

    이라는 결과를 얻게 된다.

     

    버블정렬의 경우, 계속 해서 정렬을 해가며 오름차순 정렬이 될때 까지 반복하지만,

     

    삽입정렬은 알맞은 인덱스 위치를 찾아들어간다.

     

     

    따라서,

    2 3 4 5 6 7 8 9 10 1

    같이 정렬이 많이 되어있는 상태라면

     

    비록 BigO는 O(N^2) 일지라도

     

    삽입정렬은 필요할때만 값을 이동시켜주기 때문에 다른 정렬 알고리즘 보다 훨씬 효율적이다.

     

     

    #include <stdio.h>
    
    int main(void)
    {
        int i,j,temp;
        int array[10] = {1,10,5,8,7,6,4,3,2,9};
        for(i = 0; i < 9; i++)
        {
            j=i;
            while(array[j] > array[j+1]){
                temp = array[j];
                array[j] = array[j+1];
                array[j+1] = temp;
                j--;
            }
        }
    
        for(i = 0; i < 10; i++)
        {
            printf("%d ", array[i]);
        }
    
        return 0;
    }
    728x90
    반응형

    댓글

Designed by Tistory.