삽입 정렬(Insertion Sort) 알고리즘

  • 21 minutes to read

삽입 정렬(Insertion Sort) 알고리즘은 배열의 각 요소를 이미 정렬된 부분에 올바른 위치에 삽입하는 방식으로 정렬하는 알고리즘입니다. 정렬을 시작할 때, 배열의 첫 번째 요소는 이미 정렬된 것으로 간주하고, 두 번째 요소부터 마지막 요소까지 차례대로 이미 정렬된 부분에 적절한 위치에 삽입합니다.

삽입 정렬은 다음과 같은 과정을 거칩니다:

  1. 현재 위치에서 왼쪽으로 이동하며 이미 정렬된 부분의 데이터와 비교합니다.
  2. 현재 위치의 데이터가 정렬된 부분의 데이터보다 작으면, 정렬된 부분의 데이터를 오른쪽으로 한 칸 이동시키고 1번 과정을 반복합니다.
  3. 현재 위치의 데이터가 정렬된 부분의 데이터보다 크거나 왼쪽 끝에 도달하면, 현재 위치의 데이터를 그 위치에 삽입합니다.
  4. 배열의 모든 요소가 정렬될 때까지 이 과정을 반복합니다.

삽입 정렬은 이미 부분적으로 정렬된 배열에서 효율적이며, 배열의 크기가 작을 때 유용한 정렬 알고리즘입니다. 하지만 배열의 크기가 커질수록 성능이 저하되는 단점이 있습니다.

삽입 정렬 알고리즘을 이용한 C# 프로그램 예제

삽입 정렬은 비교 기반 정렬 알고리즘 중 하나로, 각 숫자를 적절한 위치에 삽입함으로써 정렬을 수행합니다. 이 알고리즘은 이미 정렬된 부분 배열에 새로운 원소를 올바른 위치에 삽입하는 과정을 반복하여 전체 배열을 정렬합니다. 이 글에서는 C# 언어로 작성된 삽입 정렬 알고리즘 예제를 소개하고 설명합니다.

예제: 삽입 정렬 알고리즘

코드: InsertionSort.cs

using System;

namespace InsertionSortExample
{
    class Program
    {
        static void Main(string[] args)
        {
            int[] arr = new int[5];
            int temp, j;

            Console.WriteLine("5개의 정수를 입력하세요:");
            for (int i = 0; i < arr.Length; i++)
            {
                arr[i] = Convert.ToInt32(Console.ReadLine());
            }

            for (int i = 1; i < arr.Length; i++)
            {
                temp = arr[i];
                for (j = i - 1; j >= 0 && arr[j] > temp; j--)
                {
                    arr[j + 1] = arr[j];
                }
                arr[j + 1] = temp;
            }

            Console.WriteLine("정렬된 배열:");
            for (int i = 0; i < arr.Length; i++)
            {
                Console.Write($"{arr[i]} ");
            }
            Console.WriteLine();
        }
    }
}

출력 결과:

5개의 정수를 입력하세요:
3
2
1
4
5
정렬된 배열: 1 2 3 4 5

이 예제를 통해 삽입 정렬 알고리즘을 사용하여 C# 프로그램을 작성하는 방법을 배웠습니다. 이 코드는 5개의 정수를 입력받아 오름차순으로 정렬하는 간단한 프로그램입니다. 삽입 정렬 알고리즘은 코드가 짧고 이해하기 쉬우며, 작은 데이터 세트의 경우 효과적인 정렬 알고리즘입니다.

VisualAcademy Docs의 모든 콘텐츠, 이미지, 동영상의 저작권은 박용준에게 있습니다. 저작권법에 의해 보호를 받는 저작물이므로 무단 전재와 복제를 금합니다. 사이트의 콘텐츠를 복제하여 블로그, 웹사이트 등에 게시할 수 없습니다. 단, 링크와 SNS 공유, Youtube 동영상 공유는 허용합니다. www.VisualAcademy.com
박용준 강사의 모든 동영상 강의는 데브렉에서 독점으로 제공됩니다. www.devlec.com