버블 정렬, 삽입 정렬, 선택 정렬 구현
import java.util.Arrays;
public class Main {
// 오름차순 기준 정렬 알고리즘
// 버블 정렬
public static void bubbleSort(int[] arr) {
// 1.
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;
}
}
}
// 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;
}
}
}
}
// 삽입 정렬
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) {
// 1. 최소 값을 찾아 앞 쪽부터 교환하는 방식
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;
}
// 2. 최대 값을 찾아 뒤 쪽부터 교환하는 방식
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;
}
}
//출력
버블 정렬: [1, 2, 3, 4, 5, 7]
삽입 정렬: [1, 2, 3, 4, 5, 7]
선택 정렬: [1, 2, 3, 4, 5, 7]