버블 정렬은 두 인접한 데이터의 크기를 비교해 정렬하는 방법이다.

선택 정렬은 대상 데이터에서 최대나 최소 데이터를 데이터가 나열된 순으로 찾아가며 선택하는 방법이다.
최솟값 또는 최댓값을 찾고, 남은 정렬 부분의 가장 앞에 있는 데이터와 swap하는 것이 선택정렬의 핵심이다.
구현 방법이 복잡하고, 시간 복잡도도 O(n^2)으로 효율적이지 않아 코딩 테스트에서는 많이 사용하지 않는다.

삽입 정렬은 이미 정렬된 데이터 범위에 정렬되지 않은 데이터를 적절한 위치에 삽입시켜 정렬하는 방식이다.

퀵 정렬은 기준값(pivot)을 선정해 해당 값보다 작은 데이터와 큰 데이터로 분류하는 것을 반복해 정렬하는 방식이다.

병합 정렬은 분할 정복 방식을 사용해 데이터를 분할하고 분할한 집합을 정렬하며 합치는 방식이다.


기수 정렬은 값을 비교하지 않는 특이한 정렬이다.
기수 정렬은 값을 놓고 비교할 자릿수를 정한 다음 해당 자릿수만 비교한다.


import java.util.Scanner;
public class P2750_수정렬하기 {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int N = sc.nextInt();
int[] num = new int[N];
for (int i = 0; i < N; i++) num[i] = sc.nextInt();
for (int j = 0; j < N - 1; j++) {
int swap = 0;
for (int i = 0; i < N - 1 - j; i++) {
if (num[i] > num[i + 1]) {
int hap = num[i + 1];
num[i + 1] = num[i];
num[i] = hap;
swap++;
}
}
if (swap == 0) break;
}
for (int i = 0; i < N; i++) System.out.println(num[i]);
}
}

import java.util.Scanner;
public class P1427_소트인사이드 {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
String str = sc.next();
int[] in = new int[str.length()];
for (int i = 0; i < in.length; i++)
in[i] = Integer.parseInt(str.substring(i, i + 1));
for (int i = 0; i < in.length; i++) {
int max = i;
for (int j = i + 1; j < in.length; j++) {
if (in[max] < in[j]) max = j;
}
if (in[i] < in[max]) {
int temp = in[i];
in[i] = in[max];
in[max] = temp;
}
}
for (int i = 0; i < in.length; i++)
System.out.printf("%d", in[i]);
}
}

import java.util.Scanner;
public class P2750_수정렬하기 {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int N = sc.nextInt();
int[] num = new int[N];
for (int i = 0; i < N; i++) num[i] = sc.nextInt();
int key;
for (int i=1; i<N; i++){
int j;
key = num[i];
for (j=i-1; j>=0; j--){
if(num[j] > key)
num[j+1] = num[j];
else break;
num[j] = key;
}
}
for (int i=0; i<N; i++)
System.out.println(num[i]);
}
}

import java.io.*;
import java.util.StringTokenizer;
public class NOTE01 {
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));
StringTokenizer st = new StringTokenizer(br.readLine());
int N = Integer.parseInt(st.nextToken());
int K = Integer.parseInt(st.nextToken());
int[] arr = new int[N];
st = new StringTokenizer(br.readLine());
for (int i = 0; i < N; i++) arr[i] = Integer.parseInt(st.nextToken());
quickSort(arr, 0, N - 1, K);
bw.write(arr[K - 1] + "");
bw.flush();
bw.close();
br.close();
}
public static void quickSort(int[] arr, int L, int R, int K) {
if (L >= R) return;
int pi = partition(arr, L, R);
if (pi + 1 == K) return;
quickSort(arr, L, pi - 1, K);
quickSort(arr, pi + 1, R, K);
}
public static int partition(int[] arr, int L, int R) {
int pivot = arr[L];
int i = L;
int j = R;
while (i < j) {
while (pivot < arr[j]) j--;
while (i < j && pivot >= arr[i]) i++;
int temp = arr[j];
arr[j] = arr[i];
arr[i] = temp;
}
arr[L] = arr[i];
arr[i] = pivot;
return i;
}
}

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.StringTokenizer;
public class P11004_K번째수2 {
static int N;
static int K;
static int[] sorted;
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
StringTokenizer st = new StringTokenizer(br.readLine());
N = Integer.parseInt(st.nextToken());
K = Integer.parseInt(st.nextToken());
int[] A = new int[N];
sorted = new int[N];
st = new StringTokenizer(br.readLine());
for (int i = 0; i < N; i++) A[i] = Integer.parseInt(st.nextToken());
mergeSort(A, 0, N - 1);
System.out.println(A[K - 1]);
}
static void merge(int[] a, int m, int middle, int n) {
int i = m;
int j = middle + 1;
int k = m;
while (i <= middle && j <= n) {
if (a[i] <= a[j]) {
sorted[k] = a[i];
i++;
} else {
sorted[k] = a[j];
j++;
}
k++;
}
if (i > middle) {
for (int t = j; t <= n; t++) {
sorted[k] = a[t];
if ( k <= N-1) k++;
}
} else {
for (int t = i; t <= middle; t++) {
sorted[k] = a[t];
if ( k <= N-1) k++;
}
}
for (int t = m; t <= n; t++) {
a[t] = sorted[t];
}
}
static void mergeSort(int[] a, int m, int n) {
if (m < n) {
int middle = (m + n) / 2;
mergeSort(a, m, middle);
mergeSort(a, middle + 1, n);
merge(a, m, middle, n);
}
}
}
