冒泡排序、选择排序、插入排序

2021-11-10  本文已影响0人  摇摆苏丹
import java.lang.reflect.Method;
import java.util.Arrays;
import java.util.List;
import java.util.Random;

public class BasicSort {
    private static BasicSort basicSort = new BasicSort();

    private static void swap(int[] arr, int x, int y) {
        int tmp = arr[x];
        arr[x] = arr[y];
        arr[y] = tmp;
    }

    public void bubbleSort(int[] arr) {
        // System.out.println("bubble sort" + arr);
        for (int i = arr.length - 1; i > 0; i--) {
            for (int j = 0; j < i; j++) {
                if (arr[j] > arr[j + 1]) {
                    swap(arr, j, j + 1);
                }
            }
        }
        // System.out.println(Arrays.toString(arr));
    }

    public void insertSort(int[] arr) {
        // System.out.println("insert sort" + arr);
        for (int i = 1; i < arr.length; i++) {
            for (int j = i; j > 0; j--) {
                // 合适的位置就是自己右边的都比自己大
                if (arr[j] < arr[j - 1]) {
                    swap(arr, j, j - 1);
                }
            }
        }
        // System.out.println(Arrays.toString(arr));
    }

    public void insertSort2(int[] arr) {
        // System.out.println("insert sort" + arr);
        for (int i = 1; i < arr.length; i++) {
            int tmp = arr[i];
            int idx = i - 1;
            while (idx >= 0 && arr[idx] > tmp) {
                idx--;
            }
            // 循环执行结束后,idx指向第一个小于等于tmp的位置
            for (int j = i; j > idx + 1; j--) {
                arr[j] = arr[j - 1];
            }
            arr[idx + 1] = tmp;
        }
        // System.out.println(Arrays.toString(arr));
    }

    public void selectSort(int[] arr) {
        // System.out.println("select sort" + arr);
        for (int i = 0; i < arr.length - 1; i++) {
            int idx = i;
            for (int j = i + 1; j < arr.length; j++) {
                if (arr[j] < arr[idx]) {
                    idx = j;
                }
            }
            swap(arr, i, idx);
        }
        // System.out.println(Arrays.toString(arr));
    }

    public static void runBenchMark(int size, int min, int max, boolean validate, long seed,
            List<String> methodStringList) throws Exception {
        Random random = new Random(seed);
        int[] arr = new int[size];
        for (int i = 0; i < size; i++) {
            // arr[i] = (int) ((max - min) * Math.random()) + min;
            arr[i] = random.nextInt(min, max);
        }
        int[] standard = Arrays.copyOf(arr, arr.length);
        long startTime = System.currentTimeMillis();
        Arrays.sort(standard);
        long endTime = System.currentTimeMillis();
        String duration = (endTime - startTime) / 1000.0 + " ms\n";
        StringBuilder sb = new StringBuilder();
        sb.append(duration);
        // System.out.println(Arrays.toString(arr));
        for (String methodString : methodStringList) {
            sb.append(methodString + "\t");
            Class[] parameterTypes = new Class[] { int[].class };// 只有方法名不能唯一确定一个方法的存在
            Method method = BasicSort.class.getMethod(methodString, parameterTypes);
            int[] mine = Arrays.copyOf(arr, arr.length);
            startTime = System.currentTimeMillis();
            method.invoke(basicSort, mine);
            endTime = System.currentTimeMillis();
            duration = (endTime - startTime) / 1000.0 + " ms\t";
            sb.append(duration);
            if (validate) {
                boolean flag = Arrays.equals(mine, standard);
                sb.append(flag + "\n");
            }
        }
        System.out.println(sb.toString());
    }

    public static void main(String[] args) throws Exception {
        // 2^16
        runBenchMark(Integer.MAX_VALUE >> 16, 0, 100, true, 114514,
                List.of("bubbleSort", "insertSort", "insertSort2", "selectSort"));
    }
}
上一篇 下一篇

猜你喜欢

热点阅读