삽입 정렬(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개의 정수를 입력받아 오름차순으로 정렬하는 간단한 프로그램입니다. 삽입 정렬 알고리즘은 코드가 짧고 이해하기 쉬우며, 작은 데이터 세트의 경우 효과적인 정렬 알고리즘입니다.

더 깊이 공부하고 싶다면
DevLec에서는 실무 중심의 C#, .NET, ASP.NET Core, Blazor, 데이터 액세스 강좌를 단계별로 제공합니다. 현재 수강 가능한 강좌 외에도 더 많은 과정이 준비되어 있습니다.
DevLec.com에서 자세한 커리큘럼을 확인해 보세요.
DevLec 공식 강의
C# Programming
C# 프로그래밍 입문
프로그래밍을 처음 시작하는 입문자를 위한 C# 기본기 완성 과정입니다.
ASP.NET Core 10.0
ASP.NET Core 10.0 시작하기 MVC Fundamentals Part 1 MVC Fundamentals Part 2
웹 애플리케이션의 구조와 MVC 패턴을 ASP.NET Core로 실습하며 익힐 수 있습니다.
Blazor Server
풀스택 웹개발자 과정 Part 1 풀스택 웹개발자 과정 Part 2 풀스택 웹개발자 과정 Part 3
실무에서 바로 활용 가능한 Blazor Server 기반 관리자·포털 프로젝트를 만들어 봅니다.
Data & APIs
Entity Framework Core 시작하기 ADO.NET Fundamentals Blazor Server Fundamentals Minimal APIs
데이터 액세스와 Web API를 함께 이해하면 실무 .NET 백엔드 개발에 큰 도움이 됩니다.
VisualAcademy Docs의 모든 콘텐츠, 이미지, 동영상의 저작권은 박용준에게 있습니다. 저작권법에 의해 보호를 받는 저작물이므로 무단 전재와 복제를 금합니다. 사이트의 콘텐츠를 복제하여 블로그, 웹사이트 등에 게시할 수 없습니다. 단, 링크와 SNS 공유, Youtube 동영상 공유는 허용합니다. www.VisualAcademy.com
박용준 강사의 모든 동영상 강의는 데브렉에서 독점으로 제공됩니다. www.devlec.com