병합 알고리즘

  • 10 minutes to read

병합(MERGE) 알고리즘 소개

병합 알고리즘은 2개의 정렬된 배열을 합쳐 하나의 정렬된 배열로 만드는 데 사용됩니다.

병합(MERGE) 알고리즘 사용하기

다음은 오름차순으로 정렬되어 있는 두 정수 배열(first, second)을 병합하여 오름 차순 정렬된 배열(merge)을 완성하는 예제입니다. 처리 조건은 다음과 같습니다.

  • 배열 first1 ~ M까지, 배열 second1 ~ N까지의 자료가 있습니다.
  • 배열 mergeM + N개의 개수가 있습니다.
  • i, j, k는 배열 첨자 변수로 사용됩니다.

그림: 병합 알고리즘 소개

병합 알고리즘 소개

병합 정렬 알고리즘 순서도

다음 그림은 병합 알고리즘을 A(I), B(K), C(K) 배열로 표현해 본 Microsoft Visio로 그린 참고용 순서도입니다.

다음은 오름차순된 두 배열을 병합하여 오름차순 배열을 갖는 C(K) 배열을 완성하는 알고리즘입니다.

실제 예제 코드에서는 A 대신에 first, B 대신에 second, C 대신에 merge 이름으로 코드를 작성하였습니다.

그림: 병합 정렬 알고리즘 순서도

병합 정렬 알고리즘 순서도

오른차순으로 정렬된 두 정수 배열 병합

merge_sort.c, 알고리즘_병합(MEARGE).c

/*
    병합(MEARGE) 알고리즘 : 오름차순으로 나열된 두 그룹의 데이터를 한 그룹의 데이터로 병합한다.
    (1) 데이터 a, b 중에 어느 한 쪽이 끝에 도달할 때까지 다음을 반복
    (2) a(i)와 b(j)를 비교해서 작은쪽을 c(k)에 복사하고 작은 쪽의 첨자를 +1한다.
    (3) 둘 중에 아직 끝까지 도달하지 않은 데이터를 끝까지 복사한다.
*/
#include <stdio.h>

#define M 10
#define N 5

int main(void)
{
    //[1] Init/Input
    static int a[] = { 2, 4, 6, 8, 10, 12, 14, 16, 18, 20 };
    static int b[] = { 1, 3, 5, 7, 9 };
    static int c[M + N];. //병합된 데이터 저장

    //[2] Process
    int i, j, k;

    i = j = k = 0;

    while (i < M && j < N). //a[], b[] 모두 끝에 도달하지 않은 동안
    {
        if (a[i] <= b[j])
        {
            c[k++] = a[i++];
        }
        else
        {
            c[k++] = b[j++];
        }
    }

    while (i < M). . //a[]가 끝에 도달할 때까지
    {
        c[k++] = a[i++];
    }

    while (j < N). . //b[]가 끝에 도달할 때까지
    {
        c[k++] = b[j++];
    }

    //[3] Output
    for (i = 0; i < M + N; i++)
    {
        printf("%d ", c[i]);
    }
    printf("\n");

    return 0;
}
1 2 3 4 5 6 7 8 9 10 12 14 16 18 20

마무리

병합 알고리즘(병합 정렬 알고리즘)의 공식과 같은 코드 모양입니다. 코드 내의 주석을 읽으면서 직접 입력한 후 결과를 확인하길 권장합니다.

참고: 병합 알고리즘 관련 질문과 답변

https://www.dotnetkorea.com/BoardView?BoardName=Qna&Num=1039

merge[k] = first[i];
k++;
i++;

위 세 줄을 한 줄로 줄인 코드가 다음 코드입니다.

merge[k++] = first[i++];

병합 정렬 알고리즘은 이미 정렬된 두 개의 배열을 합쳐서 그 결괏값도 정렬된 형태로 나오는게 목적입니다. 제가 책에도 썼지만, 12개 알고리즘은 공식과 같은 알고리즘이기에, 수학 공식 암기 형태로 익혀두시면 좋습니다. 그리고, Visual Studio 2022에서 F11번 계속 반복하면서 실행해보시면 코드 흐름을 익히는데 도움이 되실 겁니다.

더 깊이 공부하고 싶다면
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