package outer;
import java.util.Arrays;
public class Test{
public static void main(String[] args) {
int[] arr = {8, 7, 4, 5, 2, 0, 6, 1};
// bubble(arr);
// select(arr);
// insert(arr);
quick(arr, 0, arr.length-1);
System.out.println(Arrays.toString(arr));
}
// 快速
private static void quick(int[] arr, int start, int end) {
if(start >= end){
return;
}
int init = start;
int r = end;
int init_value = arr[init];
while (start < end){
while (start < end && arr[end] >= init_value){
end--;
}
while (start < end && arr[start] <= init_value){
start++;
}
if(start < end){
int temp = arr[start];
arr[start] = arr[end];
arr[end] = temp;
}
}
init_value = arr[start];
arr[start] = arr[init];
arr[init] = init_value;
quick(arr, init, start-1);
quick(arr, start+1, r);
}
// 插入
// 遍历排好的顺序,再插入
private static void insert(int[] arr) {
int temp;
for (int i = 1; i < arr.length; i++) {
for (int j = i; j > 0; j--) {
if(arr[j] < arr[j-1]){
temp = arr[j];
arr[j] = arr[j-1];
arr[j-1] = temp;
}else {
break;
}
}
}
}
// 选择
// 遍历,每次选出最值放在位置上
private static void select(int[] arr) {
int temp;
for (int i = 0; i < arr.length - 1; i++) {
for (int r = i+1; r < arr.length; r++) {
if(arr[i] > arr[r]){
temp = arr[i];
arr[i] = arr[r];
arr[r] = temp;
}
}
}
}
// 冒泡
// 两两遍历, 每次也都能析出最值
private static void bubble(int[] arr) {
int temp;
for (int length = arr.length - 1; length > 0; length--) {
for (int i = 0; i < length; i++) {
if(arr[i] > arr[i+1]){
temp = arr[i];
arr[i] = arr[i+1];
arr[i+1] = temp;
}
}
}
}
}
Java排序
最新推荐文章于 2023-05-08 09:45:10 发布