快速排序:
import java.util.Arrays;
public class QuickSort {
public static void quickSort(int[] arr, int start, int end) {
if (start < end) {
// 把数组中的第0个数字作为标准数
int sd = arr[start];
// 记录需要排序的下标
int low = start;
int high = end;
// 循环找比标准数大的数和比标准数小的数
while (low < high) {
while (low < high && sd <= arr[high]) {
high--;
}
// 使用右边的数字替换左边的数
arr[low] = arr[high];
// 如果左边的数字比标准数小
while (low < high && arr[low] <= sd) {
low++;
}
arr[high] = arr[low];
}
// 把标准数赋给低所在的位置的元素
arr[low] = sd;
// 处理所有小的数字
quickSort(arr, start, low);
// 处理所有大的数字
quickSort(arr, low + 1, end);
}
}
public static void main(String[] args) {
int[] arr = new int[] { 3, 4, 6, 7, 2, 7, 2, 8, 0 };
quickSort(arr, 0, arr.length - 1);
System.out.println(Arrays.toString(arr));
}
}
2.插入排序
public static void insertSort(int[] arr) {
//遍历所有数字
for(int i=1;i<arr.length;i++) {
//如果当前数字比前一个数字小
if(arr[i]<arr[i-1]) {
//把当前遍历的数字存起来
int j;
int temp = arr[i];
//遍历当前数字前面所有的数字
for (j = i - 1; j >= 0 && arr[j] > temp; j--) {
//把前一个数字赋给后一个数字
arr[j + 1] = arr[j];
}
//把临时变量(外层for循环的当前元素)赋给不满足条件的后一个元素
arr[j + 1] = temp;
}
}
}