이진 검색 알고리즘

  • 26 minutes to read

이진 검색 알고리즘은 컴퓨터 과학에서 광범위하게 사용되는 검색 기법 중 하나로, 정렬된 데이터에서 원하는 값을 빠르고 효율적으로 찾을 수 있는 방법입니다. 이 알고리즘은 배열의 중앙 요소를 기준으로 목표 값과의 관계를 평가하여, 검색 범위를 반으로 줄여나가는 방식으로 작동합니다. 이 글에서는 다양한 프로그래밍 언어로 구현된 이진 검색 알고리즘의 예제를 살펴보며, 이진 검색 알고리즘이 어떻게 작동하는지 이해해보겠습니다. 이진 검색 알고리즘의 시간 복잡도는 O(log n)이며, 정렬된 데이터에서 선형 검색보다 월등히 빠른 속도로 원하는 값을 찾을 수 있습니다. 다양한 프로그래밍 언어로 구현된 이진 검색 알고리즘 예제를 통해, 이진 검색 알고리즘의 핵심 원리와 사용법을 익혀보세요.

C 언어로 구현한 이진 검색

이번 글에서는 C 언어로 이진 검색(Binary Search) 알고리즘을 구현해보겠습니다. 이진 검색 알고리즘은 정렬된 배열에서 효율적으로 원하는 값을 찾을 수 있는 검색 알고리즘입니다. 정렬된 배열이 주어지면, 이진 검색은 검색 범위를 반씩 줄여가면서 목표 값을 찾거나 검색 범위가 없어질 때까지 검색을 진행합니다.

다음은 이진 검색 알고리즘을 구현한 소스 코드입니다:

코드: binary_search_c.c

// 이진(이분) 검색(탐색) : Binary Search :
// - 데이터가 정렬되어있다고 가정 : 다른 정렬 알고리즘 활용
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdbool.h>

int main(void)
{
    int data[] = { 1, 4, 5, 7, 9 };
    int search;
    int low = 0;
    int mid = 0;
    int high = sizeof(data) / sizeof(int) - 1; // N - 1
    bool flag = false; // 못 찾았다를 가정.

    printf("검색할 데이터: ");
    scanf("%d", &search);

    while (low <= high)
    {
        mid = (low + high) / 2; // 반씩 끊어서 검색
        if (data[mid] == search)
        {
            printf("%d을(를) %d 인덱스에서 찾았습니다.\n", search, mid);
            flag = true;
            break; // 찾았으면 종료
        }
        if (data[mid] < search)
        {
            low = mid + 1; // 작은 것은 검색할 필요없음
        }
        else
        {
            high = mid - 1; // 큰 것은 검색할 필요없음
        }
    }
    if (!flag)
    {
        printf("%d은(는) 찾을 수 없습니다...\n", search);
    }

    return 0;
}
검색할 데이터: 7
7을(를) 3 인덱스에서 찾았습니다.
검색할 데이터: 3
3은(는) 찾을 수 없습니다...

이진 검색 알고리즘은 정렬된 배열에서만 사용할 수 있으며, 시간 복잡도는 O(log n)입니다. 따라서 정렬된 배열에서 특정 값을 찾을 때 이진 검색은 선형 검색보다 훨씬 빠르게 값을 찾을 수 있습니다. 이 코드는 기본적인 이진 검색 알고리즘 구조를 사용하며, 정렬된 배열에서 목표 값을 찾거나 존재하지 않을 경우 알려줍니다. 검색 범위를 반으로 줄여나가는 것이 이진 검색의 핵심이며, 이 과정을 통해 원하는 값을 효율적으로 찾을 수 있습니다.

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