数据结构与算法之选择排序

上一篇说了冒泡排序,这次说选择排序.选择排序与冒泡排序十分相似.冒泡排序是每一轮中的每一次都讲最小值交换.而选择排序是将每一轮中最小的值记录下标记录下来,一轮过后只交换一次,从空间上来说比冒泡排序好.

但是从时间复杂度来说是一样的.此算法的时间复杂度为O(n^2)

public static void xuanze(int[] arr) {
        for (int i = 0; i < arr.length; i++) {
            int min =i;
            for (int x = i + 1; x < arr.length; x++) {
                if (arr[x] < arr[min]) {
                    min = x;
                }
            }
           int temp = arr[i];
            arr[i] = arr[min];
            arr[min] = temp;
        }
    }

以下提供了一个测试方法.

public static void main(String[] args) {
        Random random = new Random();
        while (true) {
            int length = random.nextInt(100);
            int[] arr = new int[length];
            int[] arr2 = new int[length];
            for (int x = 0; x < length; x++) {
                int i = random.nextInt(100);
                arr[x] = i;
                arr2[x] = i;
            }
            xuanze(arr);
            Arrays.sort(arr2);
            boolean equals = Arrays.equals(arr2, arr);
            System.out.println(equals);
            if (!equals) {
                break;
            }
        }
    }

 

posted @ 2022-04-17 16:22  顶风少年  阅读(22)  评论(0编辑  收藏  举报
返回顶部