# 解题思路 or 实现原理
选择排序是一种简单直观的排序算法 d
, 无论什么数据进去都是 O(n²)
的时间复杂度。所以用到它的时候d
, 数据规模越小越好。唯一的好处可能就是不占用额外的内存空间了吧。
# 算法步骤
首先在未排序序列中找到最小(大)元素
d
, 存放到排序序列的起始位置;再从剩余未排序元素中继续寻找最小(大)元素
d
, 然后放到已排序序列的末尾;重复第二步d, 直到所有元素均排序完毕。
# 实现代码
/*
* @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
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