package com.kaibing.sort;
import org.junit.jupiter.api.Test;
public class UpSort {
public int[] arr = {1, 3, 2, 7, 5};
/**
* 冒泡排序:思想每次把目标(最大或最小)移到末尾
* 时间:平均=O(n^2) | 最坏=O(n^2) |最好=O(N)
* 空间:O(1)
* 稳定性:稳定
*/
@Test
public void testFast() {//冒泡排序
// 从小到大
for (int i = 0; i < arr.length; i++) {
for (int j = i + 1; j < arr.length; j++) {
if (arr[i] > arr[j]) {
int temp = arr[i];
arr[i] = arr[j];
arr[j] = temp;
}
}
}
for (int i = 0; i < arr.length; i++) {
System.out.println(arr[i]);
}
System.out.println("================");
// 从大到小
for (int i = 0; i < arr.length; i++) {
for (int j = i + 1; j < arr.length; j++) {
if (arr[i] < arr[j]) {
int temp = arr[i];
arr[i] = arr[j];
arr[j] = temp;
}
}
}
for (int i = 0; i < arr.length; i++) {
System.out.println(arr[i]);
}
}
/**
* 插入排序:把第i为的数与前面的相比较,找到合适的位置插入,并把要出入位置之后的数字都向后移
* 时间:平均=O(n^2) | 最坏=O(n^2) | 最好O(n)
* 空间:O(1)
* 稳定性:稳定
*/
@Test
public void insertSort() {
for (int i = 1; i < arr.length; i++) {
int j = 0;//记录位置
int temp = arr[i];//保存要插入的数据
for (j = i - 1; j >= 0; j--) {
//因为前面的i为都已经时排好序的
if (temp < arr[j]) {
arr[j + 1] = arr[j];
} else {
break;
}
}
arr[j + 1] = temp;
}
for (int i = 0; i < arr.length; i++) {
System.out.println(arr[i]);
}
}
/**
* 快速排序:找基准点=把数组分成两块,找到基准点的位置,分成左右两个,递归
* 时间:平均=O(Nlog2N) | 最坏=O(N2) | 最好O(Nlog2N)
* 空间:O(Nlog2N)
* 稳定性:不稳定
*/
@Test
public void quickSort() {
quickSortBody(0, arr.length - 1, arr);
for (int i = 0; i < arr.length; i++) {
System.out.println(arr[i] + "===" + arr.length);
}
}
public void quickSortBody(int start, int end, int[] arr) {
if (start >= end) {
return;
}
//选择基准点
int temp = arr[start];
int startIndex = start;
int endIndex = end;
while (start < end) {
while (start < end) {
if (arr[end] < temp) {
break;
}
end--;
}
while (start < end) {
if (arr[start] > temp) {
break;
}
start++;
}
if (start < end) {
int tem = arr[start];
arr[start] = arr[end];
arr[end] = tem;
}
}
if (start == end) {
int tem = arr[startIndex];
arr[startIndex] = arr[end];
arr[end] = tem;
}
if (start == end && end < arr.length - 2) {
quickSortBody(startIndex, end - 1, arr);
quickSortBody(end + 1, endIndex, arr);
}
}
}