버블 정렬 알고리즘을 이용한 C 언어 프로그램 예제

  • 3 minutes to read

버블 정렬은 간단하면서도 효과적인 정렬 알고리즘 중 하나입니다. 이 알고리즘은 인접한 원소들을 비교하여 필요한 경우 교환하는 과정을 반복함으로써 배열을 정렬합니다. 이 글에서는 C 언어를 사용한 버블 정렬 알고리즘 예제를 소개합니다.

  1. 헤더 파일 및 매크로 정의

    첫 번째 단계로, 필요한 헤더 파일을 포함하고 배열의 크기를 정의하는 매크로를 작성합니다.

#include <stdio.h>
#define SIZE 5
  1. main 함수 및 변수 선언

    main 함수를 작성하고, 정수 배열과 임시 변수를 선언합니다.

int main() {
    int arr[SIZE], temp;
  1. 사용자 입력

    사용자로부터 배열에 들어갈 5개의 정수를 입력받습니다.

    printf("5개의 정수를 입력하세요: ");
    for (int i = 0; i < SIZE; i++) {
        scanf("%d", &arr[i]);
    }
  1. 버블 정렬 알고리즘 구현

    버블 정렬 알고리즘을 사용하여 입력받은 정수들을 오름차순으로 정렬합니다.

    for (int i = 0; i < SIZE - 1; i++) {
        for (int j = 0; j < SIZE - 1 - i; j++) {
            if (arr[j] > arr[j + 1]) {
                temp = arr[j];
                arr[j] = arr[j + 1];
                arr[j + 1] = temp;
            }
        }
    }
  1. 정렬된 배열 출력

정렬된 배열을 출력하여 사용자에게 결과를 보여줍니다.

    printf("정렬된 배열: ");
    for (int i = 0; i < SIZE; i++) {
        printf("%d ", arr[i]);
    }
    printf("\n");
    return 0;
}

전체 소스는 다음과 같습니다.

코드: bubble_sort_size.c

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#define SIZE 5

int main(void) 
{
    int arr[SIZE], temp;
    printf("5개의 정수를 입력하세요:\n");
    for (int i = 0; i < SIZE; i++) 
    {
        scanf("%d", &arr[i]);
    }
    for (int i = 0; i < SIZE - 1; i++) 
    {
        for (int j = 0; j < SIZE - 1 - i; j++) 
        {
            if (arr[j] > arr[j + 1]) 
            {
                temp = arr[j];
                arr[j] = arr[j + 1];
                arr[j + 1] = temp;
            }
        }
    }
    printf("정렬된 배열: ");
    for (int i = 0; i < SIZE; i++) 
    {
        printf("%d ", arr[i]);
    }
    printf("\n");
    return 0;
}
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