选择排序

目录

选择排序(第一种)(不稳定):

代码实现:

思路分析:

选择排序(第二种)(不稳定):

代码实现:

思路分析:


选择排序(第一种)(不稳定):

代码实现:

复制代码
 public static void selectSort(int[] arr) {
        for (int i = 0; i < arr.length; i++) {
            int mindex = i;
            for (int j = i + 1; j < arr.length; j++) {
                if(arr[mindex] > arr[j]) {
                    mindex = j;
                }
            }
            //交换
            swap(arr,mindex,i);
        }
    }

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

思路分析:

首先,每一次在 i 循环开始后,使用 mindex 记录 其 i 下标值的大小,之后,j 每次在 i 后一个元素开始循环,如果过程遇到 下标值 比 mindex下标值更小的,mindex 下标更新成小的下标,直到一轮 j 的循环结束,就能找到此过程与 i 下标相比最小的元素下标,再进行交换。 使得最小的元素放到了前面。

选择排序(第二种)(不稳定):

代码实现:

复制代码
 public static void selectSort2(int[] arr) {
        int left = 0;
        int right = arr.length - 1;
        while(left < right) {
            int mindex = left;
            int maxdex = left;
            for (int i = left + 1; i <= right ; i++) {
                if(arr[mindex] > arr[i]) {
                    mindex = i;
                }
                if(arr[maxdex] < arr[i]) {
                    maxdex = i;
                }
            }
            swap(arr,mindex,left);
            假设第一个值 是最大值
            if(maxdex == left) {
                maxdex = mindex;
            }
            swap(arr,maxdex,right);
            left++;
            right--;
        }
    }

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

思路分析:

使用两个变量 mindex 和 maxdex 记录遍历过程中最小值的下标和最大值的下标。

先给定 mindex 和 maxdex 的下标为 left ,定义一个变量 i ,从 left + 1 的位置开始,不断往后走更新mindex 和 maxdex ,找到包含 left 和 right 之间 的最大值 和最小值的下标,再将其left 与最小值下标mindex交换,right 与 最大值 maxdex 交换,然后left 加加,right减减,缩小范围,不断重复此过程,直至left 与 right相遇停止。

值得注意的是,如果最大值下标 maxdex 是 left 的位置,那么在 left 和 mindex 的下标值交换后,left 下标的最大值跑到了 mindex 的位置去了,所有要把 maxdex 赋值成 mindex。

选择排序效率不是很好。实际中很少使用。

相关推荐
凡人叶枫8 分钟前
C++中智能指针详解(Linux实战版)| 彻底解决内存泄漏,新手也能吃透
java·linux·c语言·开发语言·c++·嵌入式开发
Tony Bai8 分钟前
再见,丑陋的 container/heap!Go 泛型堆 heap/v2 提案解析
开发语言·后端·golang
power 雀儿14 分钟前
掩码(Mask)机制 结合 多头自注意力函数
算法
会叫的恐龙18 分钟前
C++ 核心知识点汇总(第六日)(字符串)
c++·算法·字符串
JMchen12323 分钟前
Android后台服务与网络保活:WorkManager的实战应用
android·java·网络·kotlin·php·android-studio
小糯米60129 分钟前
C++顺序表和vector
开发语言·c++·算法
froginwe1135 分钟前
JavaScript 函数调用
开发语言
阔皮大师39 分钟前
INote轻量文本编辑器
java·javascript·python·c#
独望漫天星辰39 分钟前
C++ 多态深度解析:从语法规则到底层实现(附实战验证代码)
开发语言·c++
小法师爱分享42 分钟前
StickyNotes,简单便签超实用
java·python