掌握常见的几种排序-选择排序

简介: 选择排序是一种简单的排序,时间复杂度是O(n^2),在未排序的数组中找到最小的那个数字,然后将其放到起始位置,从剩下未排序的数据中继续寻找最小的元素,将其放到已排序的末尾,以此类推,直到所有元素排序结束为止。

选择排序是一种简单的排序,时间复杂度是O(n^2),在未排序的数组中找到最小的那个数字,然后将其放到起始位置,从剩下未排序的数据中继续寻找最小的元素,将其放到已排序的末尾,以此类推,直到所有元素排序结束为止。


我们先看下选择排序的一段代码

function selectSort(arr) {
  const len = arr.length;
  var minIndex, temp;
  for (let i=0;i<len;i++) {
      minIndex = i; //假设当前循环索引是最小元素
      for (let j=i+1;j<len;j++) {
          if (arr[j] < arr[minIndex]) {
              minIndex = j; // 寻找最小的值
          }
      }
      // 交换minIndex与i元素的值
      temp = arr[i];
      arr[i] = arr[minIndex];
      arr[minIndex] = temp;
  }
  return arr;
}
selectSort([6,12,80,91,8,0]);

我们画个图还原排序所有过程,具体如下

609e7d9fc6b2c7cf4aaff30c984a96c2.png

从每次循环中我们可以知道选择排序,实际上就是先确认起始位置的索引,假设第一个是最小位置,从剩余元素中找到比第一个位置小的值,如果剩余的元素有比它小,那么确认当前索引为最小索引值,并交换两个元素的位置。


然后再从第二元素开始,假设第二元素是最小值,然后从剩余元素中找最小的元素,如果剩余元素有比它小就交换位置,如果没有,就正常不交换位置,直到循环到最后一个元素为止。


再言简意赅点,选择排序就是


1、假设第一个元素是最小值


2、从剩余元素中选择与第一个元素比较元素大小,确认最小索引值,然后交换位置


3、从剩余位置依次循环,假设剩余位置为最小值,然后从剩余元素中选择与之进行比较,然后确认是否交换位置


4、直到循环到最后一个索引为止

7fb976780ccf52009a7e605b23555563.png


总结


1、选择排序时间复杂度是O(n^2)


2、假设首个元素是最小的元素,在剩余未排序的元素中与之进行比较,如果比它小,就确认最小位置索引,与之交换位置


3、在剩余未排序的所有的元素中,假设首个元素是最小值,然后与剩余元素进行依次比较,确认元素当前最小最小索引,交换位置,依次循环,直到最后循环结束为止



相关文章
|
3月前
|
算法 搜索推荐
排序——选择排序
排序——选择排序
18 0
|
3月前
|
搜索推荐 算法 Shell
排序——插入排序
排序——插入排序
16 0
|
6月前
|
算法 搜索推荐 索引
排序篇(二)----选择排序
排序篇(二)----选择排序
15 0
|
6月前
|
存储 搜索推荐 测试技术
排序篇(一)----插入排序
排序篇(一)----插入排序
19 0
|
9月前
|
算法 搜索推荐
排序——冒泡排序
这个算法的名字由来是因为越小的元素会经由交换慢慢“浮”到数列的顶端(升序或降序排列),就如同碳酸饮料中二氧化碳的气泡最终会上浮到顶端一样,故名“冒泡排序”。
|
10月前
|
搜索推荐
排序(2)之选择排序
继插入排序后,今天小编就给大家另一个模块,选择排序的学习,那么话不多说,我们直接进入正题。
84 0
|
10月前
|
存储 搜索推荐 测试技术
排序(1)之插入排序
从今天小编就开始给大家介绍排序的内容,对于排序内容我们一共分,插入,选择,交换,归并这几个大类,那么今天小编给大家带来的就是插入排序
70 0
|
算法 搜索推荐 API
算法排序3——选择排序
算法排序3——选择排序
75 0
算法排序3——选择排序
|
算法
排序——快速排序
排序——快速排序
93 0
排序——快速排序
|
算法
排序——直接插入排序
排序——直接插入排序
88 0
排序——直接插入排序