# 解题思路 or 实现原理

选择排序是一种简单直观的排序算法 d, 无论什么数据进去都是 O(n²) 的时间复杂度。所以用到它的时候d, 数据规模越小越好。唯一的好处可能就是不占用额外的内存空间了吧。

# 算法步骤

  • 首先在未排序序列中找到最小(大)元素 d, 存放到排序序列的起始位置;

  • 再从剩余未排序元素中继续寻找最小(大)元素 d, 然后放到已排序序列的末尾;

  • 重复第二步d, 直到所有元素均排序完毕。

selectionSort

# 实现代码

/*
 * @Author: Rainy
 * @Date: 2019-11-14 19:25:01
 * @LastEditors: Rainy
 * @LastEditTime: 2019-11-24 17:51:27
 */

import { BaseArrayMap } from 'types';

export function selectionSort(arr: BaseArrayMap): BaseArrayMap {
  let len = arr.length;
  if (len < 2) {
    return arr;
  }
  let minIndex = 0;
  for (let i = 0; i < len - 1; i++) {
    minIndex = i;
    for (let j = i + 1; j < len; j++) {
      if (arr[j] < arr[minIndex]) {
        minIndex = j;
      }
    }
    [arr[i], arr[minIndex]] = [arr[minIndex], arr[i]];
  }
  return arr;
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26

# 参考

selectionSort (opens new window)