前言

  文本来总结常见的排序算法,通过 JvavScript  来实现

正文

  1、冒泡排序

  算法思想:比较相邻两个元素的大小,如果第一个比第二个大,就交换它们。从头遍历到尾部,当一轮遍历完后,数组最后一个元素是最大的。除去最后一个元素,对剩下的元素重复执行上面的流程,每次找出剩余元素中最大的,遍历完后,数组是升序的

  算法分析:总共需要进行length * (length - 1) / 2 次比较,所以时间复杂度为O(n^2),因为只需要有一个存放常量的空间,元素本身在原数组上进行交换,所以空间复杂度为O(1)

        function bubbleSort(array) {
if (!Array.isArray(array)) {
throw new Error('参数必须为数组');
return;
}
var n = 0, m = 0 // n表示趟数,m表示比较次数
for (let i = array.length - 1; i > 0; i--) { // 外层for表示遍历的趟数
for (let j = 0; j < i; j++) { // 内层for表示每趟需要比较的 j 和 j+1 对应的数
if (arr[j] > arr[j + 1]) {
[arr[j + 1], arr[j]] = [arr[j], arr[j + 1]]
}
m++
}
n++
}
console.log("遍历趟数" + n, "比较次数" + m);//遍历趟数8 比较次数36
return array
}
var arr = [7, 3, 6, 9, 24, 0, 1, 45, 8]
console.log(bubbleSort(arr)); //[0, 1, 3, 6, 7, 8, 9, 24, 45]

  我们在每一轮循环中,可以记住最后一次交换的元素,这之后的元素就肯定是已经排完序的,这样可以减少总的循环次数

        function bubbleSort2(array) {
if (!Array.isArray(array)) {
throw new Error('参数必须为数组');
return;
}
var n = 0, m = 0 // n表示趟数,m表示比较次数
for (var i = array.length - 1; i > 0;) { // 用来表示遍历 n-1 趟
var cursor = 0; // 用来记录本轮最后一次交换的元素位置
for (var j = 0; j < i; j++) {
if (array[j] > array[j + 1]) {
cursor = j;
[arr[j + 1], arr[j]] = [arr[j], arr[j + 1]]
}
m++
}
n++
i = cursor; }
console.log("遍历趟数" + n, "比较次数" + m);//遍历趟数6 比较次数29
return array
}
var arr = [7, 3, 6, 9, 24, 0, 1, 45, 8]
console.log(bubbleSort2(arr)); //[0, 1, 3, 6, 7, 8, 9, 24, 45]

  2、选择排序

  实现思路
        (1)从头遍历到尾部,找出所有项中最大的一个元素
        (2)将这个元素和第一个元素交换
        (3)对剩下的元素重复进行上面的操作,每次找出剩余中最大的最后的数组是降序排列的
        (4) 算法分析
  总共需要进行length * (length - 1) / 2 次比较,所以时间复杂度为O(n^2),因为只需要有两个存放常     量的空间,元素本身在原数组上进行交换,所以空间复杂度为O(1)

        function selectSort(array) {
if (!Array.isArray(array)) {
throw new Error('参数必须为数组');
return;
}
for (let i = 0; i < array.length; i++) {
var maxIndex = i, maxValue = array[i] // 设置i为最大元素下标
// 找出剩下元素中的最大值,第一次循环找出最大值
for (let j = i + 1; j < array.length; j++) {
if (array[j] > maxValue) {
maxIndex = j
maxValue = array[j]
}
}
// 如果剩下的元素中最大值下标大于i则发生交换
if (maxIndex > i) {
[array[i], array[maxIndex]] = [array[maxIndex], array[i]]
}
}
return array
}
var arr = [7, 3, 6, 9, 24, 0, 1, 45, 8]
console.log(selectSort(arr)); //[45, 24, 9, 8, 7, 6, 3, 1, 0]

  3、插入排序

  实现思路

  (1)将数组前面部分看做有序数组

  (2)每次将后面部分的第一个与已排序数组作比较,插入到合适的位置

  (3)有序数组初始状态有1个数字

  (4)算法分析

  (5)时间复杂度为O(n^2)

        function insertSort(array) {
if (!Array.isArray(array)) {
throw new Error('参数必须为数组');
return;
}
for (var i = 1; i < array.length; i++) {
var temp = array[i] //当前值
for (var j = i; j > 0 && temp < array[j - 1]; j--) {
// 当前值和之前的每个值进行比较,发现有比当前值小的值就进行重新赋值
array[j] = array[j - 1];
}
array[j] = temp;
}
return array;
}
var arr = [7, 3, 6, 9, 24, 0, 1, 45, 8]
console.log(insertSort(arr)); //[45, 24, 9, 8, 7, 6, 3, 1, 0]

  4、快速排序:

  算法思想:将数组的第一个数字作为基准,最后使得基准数字位于数组中间某个位置,它的左边的数字都比它小,它的右边的数字都比它大。

  算法实现:设置两个分别指向数组头部和尾部的指针i和j,首先向左移动j,使得array[j] 小于基准。然后向右移动i,使得array[i] 大于基准,交换这两个元素。当i 和j 的值相等时,交换基准与位置i上的元素,然后对i左边以及右边的元素分别进行快速排序。

        function quickSort(array) {
const sort = function (arr, left = 0, right = arr.length - 1) {
if (left >= right) {// 递归退出条件
return
}
let i = left, j = right // 定义两个指针
let pivot = arr[i] // 定义基准数据 while (i < j) { // 把所有比基准数
while (j > i && arr[j] >= pivot) { //找到一个比基准值小的数位置为j
j--
}
arr[i] = arr[j] // 将j的值给了i位置的元素,此时j位置还是原来的数
while (i < j && arr[i] < pivot) {
i++
}
arr[j] = arr[i] // 将i位置的值给了j位置的元素,此时i的位置还是原来的数
}
// 本次交换完毕,此时ij两个指针重合,把基准值赋值给i即可
arr[i] = pivot
sort(arr, left, j - 1) // 将左边的无序数组重复上面的操作
sort(arr, j + 1, right) // 将右边的无序数组重复上面的操作
}
const newArr = array.concat() // 为了保证这个函数是纯函数拷贝一次数组
sort(newArr)
return newArr
}
var arr = [7, 3, 6, 9, 24, 0, 1, 45, 8]
console.log(quickSort(arr)); //[0, 1, 3, 6, 7, 8, 9, 24, 45]

写在最后

  以上就是本文的全部内容,希望给读者带来些许的帮助和进步,方便的话点个关注,小白的成长之路会持续更新一些工作中常见的问题和技术点。

js--js实现基础排序算法的更多相关文章

  1. 使用 js 实现十大排序算法: 快速排序

    使用 js 实现十大排序算法: 快速排序 QuickSort 快速排序 /** * * @author xgqfrms * @license MIT * @copyright xgqfrms * @c ...

  2. 使用 js 实现十大排序算法: 桶排序

    使用 js 实现十大排序算法: 桶排序 桶排序 refs xgqfrms 2012-2020 www.cnblogs.com 发布文章使用:只允许注册用户才可以访问!

  3. 使用 js 实现十大排序算法: 计数排序

    使用 js 实现十大排序算法: 计数排序 计数排序 refs xgqfrms 2012-2020 www.cnblogs.com 发布文章使用:只允许注册用户才可以访问!

  4. 使用 js 实现十大排序算法: 基数排序

    使用 js 实现十大排序算法: 基数排序 基数排序 refs xgqfrms 2012-2020 www.cnblogs.com 发布文章使用:只允许注册用户才可以访问!

  5. 使用 js 实现十大排序算法: 冒泡排序

    使用 js 实现十大排序算法: 冒泡排序 冒泡排序 refs xgqfrms 2012-2020 www.cnblogs.com 发布文章使用:只允许注册用户才可以访问!

  6. 使用 js 实现十大排序算法: 希尔排序

    使用 js 实现十大排序算法: 希尔排序 希尔排序 refs xgqfrms 2012-2020 www.cnblogs.com 发布文章使用:只允许注册用户才可以访问!

  7. 使用 js 实现十大排序算法: 插入排序

    使用 js 实现十大排序算法: 插入排序 插入排序 // 双重循环 refs xgqfrms 2012-2020 www.cnblogs.com 发布文章使用:只允许注册用户才可以访问!

  8. 使用 js 实现十大排序算法: 选择排序

    使用 js 实现十大排序算法: 选择排序 选择排序 refs xgqfrms 2012-2020 www.cnblogs.com 发布文章使用:只允许注册用户才可以访问!

  9. 使用 js 实现十大排序算法: 归并排序

    使用 js 实现十大排序算法: 归并排序 归并排序 refs js 十大排序算法 All In One https://www.cnblogs.com/xgqfrms/p/13947122.html ...

  10. 使用 js 实现十大排序算法: 堆排序

    使用 js 实现十大排序算法: 堆排序 堆排序(Heapsort)是指利用堆这种数据结构所设计的一种排序算法. 大顶堆:每个节点的值都大于或等于其子节点的值,在堆排序算法中用于升序排列: 小顶堆:每个 ...

随机推荐

  1. Junit单元测试:

    * 测试分类: 1. 黑盒测试:不需要写代码,给输入值,看程序是否能够输出期望的值. 2. 白盒测试:需要写代码的.关注程序具体的执行流程. * Junit使用:白盒测试 * 步骤: 1. 定义一个测 ...

  2. MQTT物联网通讯协议入门

    目录 一.MQTT协议概念 发布/订阅机制 MQTT客户端 Broker代理(服务器) MQTT消息结构 二.MQTT协议实现原理 MQTT连接 MQTT消息发布 MQTT订阅机制 MQTT订阅确认 ...

  3. 【职场必备】6个免费良心网站&职场办公网站(收藏血赚)

    1.随机自动生成头像的网站:https://www.tool22.com/Tools-SJTX.html2.迅捷PDF转换器:https://app.xunjiepdf.com/3.全网音乐下载:① ...

  4. Ansible Notes: module: get_facts

    功能:用来获取remote host的facts 它是一个非常基础的模块[1],playbook里面可以直接当关键字用gather_facts: False 执行set_up模块时自动调用get_fa ...

  5. 为什么HttpContextAccessor要这么设计?

    前言 周五在群里面有小伙伴问,ASP.NET Core这个HttpContextAccessor为什么改成了这个样子? 在印象中,这已经是第三次遇到有小伙伴问这个问题了,特意来写一篇记录,来回答一下这 ...

  6. es篇-es基础

    点赞再看,养成习惯,微信搜索「小大白日志」关注这个搬砖人. 文章不定期同步公众号,还有各种一线大厂面试原题.我的学习系列笔记. es基础知识 es和solr一样,都是基于Lucene的全文检索数据库 ...

  7. Halo 开源项目学习(六):事件监听机制

    基本介绍 Halo 项目中,当用户或博主执行某些操作时,服务器会发布相应的事件,例如博主登录管理员后台时发布 "日志记录" 事件,用户浏览文章时发布 "访问文章" ...

  8. Java实用类

    //String类常用方法 public int length()//获取String对象的字符序列的长度 n=s.length(); public boolean equals(String s)/ ...

  9. 1.sprng 简介

    容器(可以用来管理所有的组件(类)) 核心关注:IOC和AOP 1.IOC Inversion(反转) Of Control:控制反转 控制:资源的获取方式 1.主动式(要什么资源自己创建) Pers ...

  10. Ubuntu中安装redis

    第一种方式在线安装首要前提安装c语言编译环境,命令如下:$sudo apt-get install gcc 安装完成后可以输入$gcc --version查看版本 1.获取源码:$wget https ...