티스토리 뷰
버블 정렬(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
- counter
- function
- find
- operators
- for
- Python
- combinations
- Method
- zip
- index
- bool
- isdigit
- Lambda
- Upper
- Lower
- Built-in Functions
- isalpha
- permutations
- If
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
글 보관함