算法面经--选择排序

作者: 永不熄灭的火焰_e306 | 来源:发表于2020-06-12 21:21 被阅读0次

    选择排序

    介绍:是从欲排序的数据中,按指定的规则选出某一元素,再依规定交换位置后达到排序的目的。

    一、算法思路

    选择排序(select sorting)也是一种简单的排序方法。它的基本思想是:第一次从 arr[0]~arr[n-1]中选取最小值, 与 arr[0]交换,第二次从 arr[1]~arr[n-1]中选取最小值,与 arr[1]交换,第三次从 arr[2]~arr[n-1]中选取最小值,与 arr[2] 交换,…,第 i 次从 arr[i-1]~arr[n-1]中选取最小值,与 arr[i-1]交换,…, 第 n-1 次从 arr[n-]~arr[n-1]中选取最小值, 与 arr[n-2]交换,总共通过 n-1 次,得到一个按排序码从小到大排列的有序序列。

    实现图解:

    选择排序1.png 选择排序2.png

    [图片上传失败...(image-ebec15-1591967993075)]

    二、代码实现

     //选择排序
      public static void selectSort(int[] arr){
      for(int i=0;i<arr.length-1;i++){
      int minIndex= i;
      int min = arr[i];
      for(int  j=i+1;j<arr.length;j++){
      if(arr[j]<min){
      min = arr[j]; //重置min和minIndex
      minIndex = j;
      }
      }
      //将最小值放在arr[i],即交换
      if(minIndex!=i){
      arr[minIndex] = arr[i];
      arr[i] = min;
      }
      }
      }
    

    相关文章

      网友评论

        本文标题:算法面经--选择排序

        本文链接:https://www.haomeiwen.com/subject/ubantktx.html