美文网首页
排序:选择排序

排序:选择排序

作者: 菲利普马洛 | 来源:发表于2018-12-31 17:49 被阅读8次

基本原理

选择排序是最为简单的排序算法,非常容易理解,不信往下看。

以升序排列(就是从小排到大)来说,选择排序先选出最小的数字,放在最前面,然后选出第二小的数字,排在第二位,依次类推。遍历完整个数组之后,排序也就排好了。

例子

举个例子,假如有一个乱序数组:

[2, 6, 1, 0]

下面我们将这个数组交给选择排序。

第一轮:

  1. 锁定第一个数字 2,依次往后看有没有数字比它小。

    [2, 6, 1, 0]

  2. 发现 1 比它小:

    [2, 6, 1, 0]

  3. 交换他们的位置,将小的放到前面:

    [1, 6, 2, 0]

  4. 从 2 的位置按接着往后看,查找有没有数字比第一个数字 1 还小。

  5. 发现 0 比它小。

    [1, 6, 2, 0]

  6. 交换他们的位置,将小的放到前面:

    [0, 6, 2, 1]

  7. 到达数组末尾,第一轮排序结束。

第二轮:

  1. 锁定第二个数字 6,依次往后看有没有数字比它小。

    [0, 6, 2, 1]

  2. 参考第一轮

第三轮:

  1. 参考第二轮

第四轮:

  1. 参考第三轮

代码

我最喜欢的上代码环节:

/**
 * 指定数组,交换数组中两个元素的位置
 * @param {Array} list 数组
 * @param {Number} i 元素 1 的索引
 * @param {Number} j 元素 2 的索引
 */
const swap = (list, i, j) => {
  let temp = list[i]
  list[i] = list[j]
  list[j] = temp
}

// 选择排序
const selectSort = (list) => {
  const len = list.length

  for (let i = 0; i < len - 1; i++) {
    for (let j = i + 1; j < len; j++) {
      if (list[j] < list[i]) {
        swap(list, i, j)
      }
    }
  }
  
  return list
}

总结

选择排序,选出数组中最小的数字,放在第一位;然后选出剩下的数字中最小的,放在第二位,依次类推。知识点啊,不知道考不考。

相关文章

  • 常见排序算法

    这里介绍四种排序算法,选择排序、快速排序、归并排序、计数排序 选择排序(使用递归) 选择排序(使用循环) 快速排序...

  • 记录几个常见的排序算法

    常见的排序有:快速排序、冒泡排序、希尔排序、选择排序、插入排序、归并排序 冒泡排序: 插入排序: 选择排序: 希尔...

  • 排序 -- 选择/插入

    聊聊排序吧 冒泡排序 选择排序 插入排序 快速排序 归并排序 计数排序 桶排序 堆排序 本篇 选择排序与插入排序 ...

  • Java 常见的 8 种排序算法(内排序)

    排序分类 内部排序 插入排序:直接插入排序、希尔排序 交换排序:冒泡排序、快速排序 选择排序:直接选择排序、堆排序...

  • 排序法

    排序分 内部排序和外部排序 内部排序: 插入排序:{直接插入排序,希尔排序} 选择排序:{简单选择排序,堆排序} ...

  • 给自己备份的排序代码

    交换排序 冒泡排序 快速排序 插入排序 直接插入排序 希尔排序 选择排序 简单选择排序 堆排序

  • 算法-选择排序

    算 法:选择排序算法时间复杂度: 选择排序算法概述 选择排序伪代码 选择排序实现 选择排序算法概述 排序算法有许...

  • 算法与数据结构知识汇总(八、常见的八大排序算法)

    排序技术有:插入排序(直接插入排序、希尔排序)、选择排序(简单选择排序、堆排序)、交换排序(冒泡排序、快速排序)、...

  • 常用的两种排序-冒泡、选择

    Swift版 冒泡排序 选择排序 OC版 冒泡排序 选择排序

  • 算法

    排序 类型交换排序:冒泡排序、快速排序插入排序:直接插入排序、希尔排序选择排序:直接选择排序、堆排序归并排序基数排...

网友评论

      本文标题:排序:选择排序

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