본문 바로가기
Algorithm

정렬 알고리즘 - 거품 정렬(Bubble sort)

by DaSsom 2023. 9. 3.
import java.util.Arrays;

public class Main {
    public static void main(String[] args) {
        int[] arr = {9, 8, 7, 6, 5, 4, 3, 2, 1};
        bubble_sort(arr);
        System.out.println(Arrays.toString(Arrays.stream(arr).toArray()));
    }

    private static void bubble_sort(int[] arr) {
        int size = arr.length;
        for (int i = 1; i < size; i++) {
            for (int j = 0; j < size - i; j++) {
                if (arr[j] > arr[j + 1]) {
                    swap(arr, j, j + 1);
                }
            }
        }
    }

    private static void swap(int[] a, int i, int j) {
        int temp = a[i];
        a[i] = a[j];
        a[j] = temp;
    }
}

오름차순 정렬 후 출력결과

- 시간복잡도 : O(N^2)

- 다른 알고리즘에 비해 시간이 오래걸리는 편, 많이 사용안함

- 가장 기초적인 정렬 알고리즘 

 

 

 

 

Reference

 

Stranger's LAB

 

자바 [JAVA] - 거품 정렬 (Bubble Sort)

[정렬 알고리즘 모음] 더보기 1. 계수 정렬 (Counting Sort) 2. 선택 정렬 (Selection Sort) 3. 삽입 정렬 (Insertion Sort) 4. 거품 정렬 (Bubble Sort) - [현재 페이지] 5. 셸 정렬 (Shell Sort) 6. 힙 정렬 (Heap Sort) 7. 합병(

st-lab.tistory.com

노마드코더

'Algorithm' 카테고리의 다른 글

백준 1920번 :: 수 찾기  (0) 2023.08.11
백준 2141번 :: 우체국  (0) 2023.08.07
백준 7662번 :: 이중 우선순위 큐  (0) 2023.07.27
백준 1918번 :: 후위 표기식  (0) 2023.07.21
백준 1874번 :: 스택 수열  (0) 2023.07.13