前端实现选择排序(Selection sort)算法
前端  /  管理员 发布于 6年前   237
选择排序(Selection sort)是一种简单直观的排序算法,无论什么数据进去都是 O(n²)
的时间复杂度,所以用到它的时候,数据规模越小越好
其基本思想是:首先在未排序的数列中找到最小(or最大)元素,然后将其存放到数列的起始位置
然后再从剩余未排序的元素中继续寻找最小(or最大)元素,然后放到已排序序列的末尾
以此类推,直到所有元素均排序完毕
举个例子,一个数组为 56、12、80、91、29,其排序过程如下:
从上面可以看到,对于具有 n
个记录的无序表遍历 n-1
次,第i
次从无序表中第 i
个记录开始,找出后序关键字中最小的记录,然后放置在第 i
的位置上
直至到从第n
个和第n-1
个元素中选出最小的放在第n-1
个位置
如下动画所示:
用代码表示则如下:
function selectionSort(arr) {
var len = arr.length;
var minIndex, temp;
for (var i = 0; i < len - 1; i++) {
minIndex = i;
for (var j = i + 1; j < len; j++) {
if (arr[j] < arr[minIndex]) { // 寻找最小的数
minIndex = j; // 将最小数的索引保存
}
}
temp = arr[i];
arr[i] = arr[minIndex];
arr[minIndex] = temp;
}
return arr;
}
第一次内循环比较N - 1
次,然后是N-2
次,N-3
次,……,最后一次内循环比较1次
共比较的次数是 (N - 1) + (N - 2) + ... + 1
,求等差数列和,得 (N - 1 + 1)* N / 2 = N^2 / 2
,舍去最高项系数,其时间复杂度为 O(N^2)
从上述也可以看到,选择排序是一种稳定的排序
和冒泡排序一致,相比其它排序算法,这也是一个相对较高的时间复杂度,一般情况不推荐使用
但是我们还是要掌握冒泡排序的思想及实现,这对于我们的算法思维是有很大帮助的
路人 在
php中使用hyperf框架调用讯飞星火大模型实现国内版chatgpt功能示例中评论 教程很详细,如果加个前端chatgpt对话页面就完美了..博主 在
科学上网翻墙之v2rayN-Core客户端免费公益节点使用教程中评论 @ mashrdn 多切换几个节点测试,免费ssr是没那么稳..mashrdn 在
科学上网翻墙之v2rayN-Core客户端免费公益节点使用教程中评论 V2rayn免费节点添加上去了,youtobe无法打开网页,是怎么回事..张伟 在
科学上网翻墙之v2rayN-Core客户端免费公益节点使用教程中评论 3q!有用,不过免费节点隔天就要去git上复制新的导进去..博主 在
科学上网翻墙访问Google , 上外网神器佛跳墙VPN(永久免费)使用流程步骤中评论 该篇教程已不能用了,告知大家,免的老有老铁问我!..
Copyright·© 2019 侯体宗版权所有·
粤ICP备20027696号