import java.util.Arrays;
public class Main {
// 오름차순 기준 정렬 알고리즘
// 버블 정렬
public static void bubbleSort(int[] arr) {
for (int i = 1; i < arr.length - 1; i++) {
for (int j = 0; j < arr.length - i; j++) {
if (arr[j] > arr[j + 1]) {
int tmp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = tmp;
}
}
}
}
// 삽입 정렬
public static void insertionSort(int[] arr) {
for (int i = 1; i < arr.length; i++) {
for (int j = i; j > 0; j--) {
if (arr[j] < arr[j - 1]) {
int tmp = arr[j];
arr[j] = arr[j - 1];
arr[j - 1] = tmp;
} else {
break;
}
}
}
}
// 선택 정렬
private static void selectionSort(int[] arr) {
for (int i = 0; i < arr.length - 1; i++) {
int min = i;
for (int j = i + 1; j < arr.length; j++) {
if (arr[j] < arr[min]) {
min = j;
}
}
int tmp = arr[i];
arr[i] = arr[min];
arr[min] = tmp;
}
}
public static void main(String[] args) {
// Test code
int[] arr = {3, 5, 2, 7, 1, 4};
bubbleSort(arr);
System.out.println("버블 정렬: " + Arrays.toString(arr));
arr = new int[]{3, 5, 2, 7, 1, 4};
insertionSort(arr);
System.out.println("삽입 정렬: " + Arrays.toString(arr));
arr = new int[]{3, 5, 2, 7, 1, 4};
selectionSort(arr);
System.out.println("선택 정렬: " + Arrays.toString(arr));
}
}
-시간복잡도 : O(n^2)
-두 개의 반복문을 사용하여, 내부 반복문에서 인접한 원소를 비교하고 교체
삽입정렬 (Insertion Sort)
-동작원리 : 배열을 순차적으로 탐색하며, 현재 원소를 적절한 위치에 삽입하여 정렬된 부분 배열을 유지
-시간복잡도 : O(n^2)
-외부 반복문은 배열을 순차적으로 탐색하고, 내부 반복문은 현재 원소의 정렬된 부분 배열의 올바른 위치에 삽입
선택정렬 (Selection Sort)
-동작원리 : 배열을 순차적으로 탐색하며, 현재 위치에 대해 가장 작은 원소를 찾아 교환. 이를 통해 배열을 정렬
-시간복잡도 : O(n^2)
-두 개의 반복문을 사용하여, 내부 반복문에서 현재 위치에 대해 가장 작은 원소를 찾아 교환
for (int i = arr.length - 1; i > 0; i--) {
for (int j = 0; j < i; j++) {
if (arr[j] > arr[j + 1]) {
int tmp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = tmp;
}
}
}
for (int i = arr.length - 1; i > 0; i--) {
int max = i;
for (int j = i - 1; j >= 0; j--) {
if (arr[j] > arr[max]) {
max = j;
}
}
int tmp = arr[i];
arr[i] = arr[max];
arr[max] = tmp;
}