java算法及数据结构and面经

算法面经--选择排序

2020-06-12  本文已影响0人  永不熄灭的火焰_e306

选择排序

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

一、算法思路

选择排序(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;
  }
  }
  }
上一篇下一篇

猜你喜欢

热点阅读