티스토리 뷰
버블 정렬(Bubble Sort)은 매우 간단한 정렬 알고리즘 중 하나입니다.
버블 정렬은 인접한 두 요소를 비교하여 잘못된 순서로 되어 있으면 그 둘을 교환하는 방식으로 동작합니다.
이 과정이 배열이 정렬될 때까지 반복합니다.
장점과 단점
- 장점: 구현이 매우 간단하고 코드가 직관적이다.
- 단점: 평균 및 최악의 경우 시간 복잡도가 O(n²)으로, 큰 데이터 집합을 다룰 때 비효율적이다.
public class BubbleSortExample {
    public static void bubbleSort(int[] arr) {
        int n = arr.length;
        boolean swapped;
        for (int i = 0; i < n - 1; i++) {
            swapped = false;
            // 마지막 i개의 요소는 이미 정렬되었으므로 제외
            for (int j = 0; j < n - 1 - i; j++) {
                // 인접한 요소들을 비교하여 잘못된 순서라면 교환
                if (arr[j] > arr[j + 1]) {
                    // swap arr[j] and arr[j + 1]
                    int temp = arr[j];
                    arr[j] = arr[j + 1];
                    arr[j + 1] = temp;
                    swapped = true;
                }
            }
            // 만약 어떤 교환도 일어나지 않았다면 배열이 이미 정렬된 것이므로 종료
            if (!swapped) break;
        }
    }
    public static void main(String[] args) {
        int[] arr = {64, 34, 25, 12, 22, 11, 90};
        System.out.println("Before sorting:");
        for (int num : arr) {
            System.out.print(num + " ");
        }
        bubbleSort(arr);
        for (int num : arr) {
            System.out.print(num + " ");
        }
    }
}
// 결과: 11 12 22 25 34 64 90버블 정렬은 작은 배열이나 이미 거의 정렬된 배열에서는 잘 동작하지만, 크거나 무작위로 정렬된 배열에서는 성능이 떨어집니다.
끝.
728x90
    
    
  'Java' 카테고리의 다른 글
| [Algorithms] 삽입 정렬 (0) | 2024.10.07 | 
|---|---|
| [Algorithms] 선택 정렬 (0) | 2024.09.30 | 
| [Algorithms] 스택과 큐 (0) | 2024.08.28 | 
| [Algorithms] 배열과 리스트 (0) | 2024.08.26 | 
| [Java] java.util.Arrays copyOf, copyOfRange Method (0) | 2024.05.30 | 
                      공지사항
                      
                  
                
                  
                  
                    최근에 올라온 글
                    
                
                  
                  
                    최근에 달린 댓글
                    
                
                  
                  - Total
- Today
- Yesterday
                    링크
                    
                
                  
                  
                    TAG
                    
                
                  
                  - combinations
- function
- Upper
- index
- counter
- Python
- permutations
- Lambda
- Method
- isdigit
- isalpha
- Lower
- If
- zip
- bool
- operators
- Built-in Functions
- for
- find
| 일 | 월 | 화 | 수 | 목 | 금 | 토 | 
|---|---|---|---|---|---|---|
| 1 | 2 | 3 | 4 | |||
| 5 | 6 | 7 | 8 | 9 | 10 | 11 | 
| 12 | 13 | 14 | 15 | 16 | 17 | 18 | 
| 19 | 20 | 21 | 22 | 23 | 24 | 25 | 
| 26 | 27 | 28 | 29 | 30 | 31 | 
                    글 보관함
                    
                
            