Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
80 changes: 80 additions & 0 deletions src/main/java/com/doit/algorithm/kdg/Main.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,80 @@
package com.doit.algorithm.kdg;

import java.io.BufferedReader;
import java.io.InputStreamReader;

public class Main {

public static void main(String[] args) throws Exception {
BufferedReader reader = new BufferedReader(new InputStreamReader(System.in));
int input = Integer.parseInt(reader.readLine());
int[] result = new int [input];

for (int i = 0; i < input; i++) {
result[i] = Integer.parseInt(reader.readLine());
}

quickSort(result, 0, input - 1);

for (int i = 0; i < input; i++) {
System.out.println(result[i]);
}
}

public static void mergeSort(int[] numbers, int start, int end) {
if (start == end) return;

int mid = (start + end) / 2;
mergeSort(numbers, start, mid);
mergeSort(numbers, mid + 1, end);

int[] temp = new int[end - start + 1];
int idx = 0;
int left = start;
int right = mid + 1;

while (left <= mid && right <= end) {
temp[idx++] = numbers[left] <= numbers[right] ? numbers[left++] : numbers[right++];
}

while (left <= mid) temp[idx++] = numbers[left++];
while (right <= end) temp[idx++] = numbers[right++];

for (int i = start; i <= end; i++) {
numbers[i] = temp[i - start];
}
}

private static void quickSort(int[] numbers, int left, int right) {
if (left >= right) return;

int mid = partition(numbers, left, right);
quickSort(numbers, left, mid - 1);
quickSort(numbers, mid + 1, right);
}

private static int partition(int[] numbers, int left, int right) {
int pivot = numbers[(left + right) / 2];

while (left <= right) {
while (numbers[left] < pivot) left++;
while (numbers[right] > pivot) right--;

if (left <= right) {
swap(numbers, left, right);
left++;
right--;
}
}

return left;
}

private static void swap(int[] numbers, int i, int j) {
int temp = numbers[i];
numbers[i] = numbers[j];
numbers[j] = temp;
}


}
108 changes: 108 additions & 0 deletions src/main/java/com/doit/algorithm/kdg/Problem015.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,108 @@
package com.doit.algorithm.kdg;


public class Problem015 {

public static int[] bubbleSort(int n, int[] numbers) {

for (int i = 0; i < n; i++) {
for (int j = i + 1; j < n; j++) {
int temp = 0;
if (numbers[i] > numbers[j]) {
temp = numbers[i];
numbers[i] = numbers[j];
numbers[j] = temp;
}
}
}
return numbers;
}

public static void mergeSortNumbers(int[] numbers, int start, int end) {
if (start == end) return;

int mid = (start + end) / 2;
mergeSortNumbers(numbers, start, mid);
mergeSortNumbers(numbers, mid + 1, end);

int[] temp = new int[end - start + 1];
int idx = 0;
int left = start;
int right = mid + 1;

while (left <= mid && right <= end) {
temp[idx++] = numbers[left] <= numbers[right] ? numbers[left++] : numbers[right++];
}

while (left <= mid) {
temp[idx++] = numbers[left++];
}
while (right <= end) {
temp[idx++] = numbers[right++];;
}

for (int i = start; i <= end; i++) {
numbers[i] = temp[i - start];
}
}

public static void mergeSortChars(char[] chars, int start, int end) {
if (start == end) return;

int mid = (start + end) / 2;
mergeSortChars(chars, start, mid);
mergeSortChars(chars, mid + 1, end);

char[] temp = new char[end - start + 1];
int idx = 0;
int left = start;
int right = mid + 1;

while (left <= mid && right <= end) {
temp[idx++] = chars[left] <= chars[right]? chars[left++] : chars[right++];
}

while (left <= mid) {
temp[idx++] = chars[left++];
}

while (right <= end) {
temp[idx++] = chars[right++];
}

for (int i = start; i <= end; i++) {
chars[i] = temp[i - start];
}
}

public static void quickSort(int[] numbers, int left, int right) {
if (left >= right) return;

int mid = partition(numbers, left, right);
quickSort(numbers, left, mid - 1);
quickSort(numbers, mid + 1, right);
}

private static int partition(int[] numbers, int left, int right) {
int pivot = numbers[left + right / 2];

while (left <= right) {
while (numbers[left] < pivot) left++;
while (numbers[right] > pivot) right--;

if (left <= right) {
swap(numbers, left, right);
left++;
right--;
}
}

return left;
}

private static void swap(int[] numbers, int i, int j) {
int temp = numbers[i];
numbers[i] = numbers[j];
numbers[j] = temp;
}
}
52 changes: 52 additions & 0 deletions src/test/java/com/doit/algorithm/kdg/Problem015Test.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,52 @@
package com.doit.algorithm.kdg;

import org.junit.jupiter.api.Test;

import java.util.Arrays;

import static org.assertj.core.api.Assertions.assertThat;

public class Problem015Test {

@Test
void bubbleSort() {
int n = 5;
int[] numbers = {5, 2, 3, 4, 1};

int[] result = Problem015.bubbleSort(n, numbers);

assertThat(result).containsExactly(1, 2, 3, 4 ,5);
}

@Test
void mergeSort_numbers() {
int n = 5;
int[] numbers = {5, 2, 3, 4, 1};

Problem015.mergeSortNumbers(numbers, 0, n - 1);

assertThat(numbers).containsExactly(1, 2, 3, 4 ,5);
}

@Test
void mergeSort_chars() {
int n = 5;
char[] chars = {'A', 'C', 'F', 'Z', 'B'};

Problem015.mergeSortChars(chars, 0, n - 1);

for (int i = 0; i < n; i++) {
System.out.println(chars[i]);
}
}

@Test
void quickSort() {
int n = 5;
int[] numbers = {5, 2, 3, 4, 1};

Problem015.quickSort(numbers, 0, n - 1);

assertThat(numbers).containsExactly(1, 2, 3, 4 ,5);
}
}