文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

JavaScript怎么实现四种常用排序

2023-06-29 08:00

关注

小编给大家分享一下JavaScript怎么实现四种常用排序,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!

一、插入排序

插入排序有直接插入排序,折半插入排序,希尔排序,这里只实现常用的直接插入排序

直接插入排序

将左侧序列看成一个有序序列,每次将一个数字插入该有序序列。

插入时,从有序序列最右侧开始比较,若比较的数较大,后移一位。

JavaScript怎么实现四种常用排序

function insertSort(array) {//第一个默认已经排好      for (let i = 1; i < array.length; i++) {        let target = i;        for (let j = i - 1; j >= 0; j--) {          if (array[target] < array[j]) {            [array[target], array[j]] = [array[j], array[target]]            target = j;          } else {            break;          }        }      }      return array;    }

复杂度

时间复杂度:O(n2)

空间复杂度:O(1)

稳定性

稳定

二、交换排序

(1)冒泡排序

循环数组,比较当前元素和上一个元素,如果当前元素比上一个元素小,向下冒泡。

这样一次循环之后最前一个数就是本数组最小的数。

下一次循环继续上面的操作,不循环已经排序好的数。

优化:当一次循环没有发生冒泡,说明已经排序完成,停止循环。

    function bubbleSort(array) {        //第一个循环是所需次数      for (let j = 0; j < array.length; j++) {        let complete = true;        for (let i = array.length-1; i>j; i--) {          // 比较相邻数          if (array[i] < array[i -1]) {            [array[i], array[i - 1]] = [array[i - 1], array[i]];            complete = false;          }        }        // 没有冒泡结束循环        if (complete) {          break;        }      }      return array;    }

复杂度

时间复杂度:O(n2)

空间复杂度:O(1)

稳定性

稳定

(2)快速排序

快速排序:通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据比另一部分的所有数据要小,再按这种方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,使整个数据变成有序序列。

实现步骤:

从上面的步骤中我们可以看出,快速排序也利用了分治的思想(将问题分解成一些小问题递归求解)

下面是对序列6、1、2、7、9、3、4、5、10、8排序的过程:

JavaScript怎么实现四种常用排序

JavaScript怎么实现四种常用排序

//JS自带的sort()就是快排function quickSort(array, start, end) {      if (end - start < 1) {        return;      }      const target = array[start];      let l = start;      let r = end;      while (l < r) {        while (l < r && array[r] >= target) {          r--;        }        array[l] = array[r];        while (l < r && array[l] < target) {          l++;        }        array[r] = array[l];      }      array[l] = target;      quickSort(array, start, l - 1);      quickSort(array, l + 1, end);      return array;    }

复杂度

时间复杂度:平均O(nlogn),最坏O(n2),实际上大多数情况下小于O(nlogn)

空间复杂度:O(logn)(递归调用消耗)

稳定性

不稳定

三、选择排序

(1)简单选择排序

每次循环选取一个最小的数字放到前面的有序序列中。 

JavaScript怎么实现四种常用排序

 function selectionSort(array) {      for (let i = 0; i < array.length - 1; i++) {        let minIndex = i;        for (let j = i + 1; j < array.length; j++) {          if (array[j] < array[minIndex]) {            minIndex = j;          }        }        [array[minIndex], array[i]] = [array[i], array[minIndex]];      }    }

复杂度

时间复杂度:O(n2)

空间复杂度:O(1)

稳定性

不稳定

(2)堆排序

创建一个大顶堆,大顶堆的堆顶一定是最大的元素。

交换第一个元素和最后一个元素,让剩余的元素继续调整为大顶堆。

从后往前以此和第一个元素交换并重新构建,排序完成。

 function heapSort(array) {      creatHeap(array);      console.log(array);      // 交换第一个和最后一个元素,然后重新调整大顶堆      for (let i = array.length - 1; i > 0; i--) {        [array[i], array[0]] = [array[0], array[i]];        adjust(array, 0, i);      }      return array;    }    // 构建大顶堆,从第一个非叶子节点开始,进行下沉操作    function creatHeap(array) {      const len = array.length;      const start = parseInt(len / 2) - 1;      for (let i = start; i >= 0; i--) {        adjust(array, i, len);      }    }    // 将第target个元素进行下沉,孩子节点有比他大的就下沉    function adjust(array, target, len) {      for (let i = 2 * target + 1; i < len; i = 2 * i + 1) {        // 找到孩子节点中最大的        if (i + 1 < len && array[i + 1] > array[i]) {          i = i + 1;        }        // 下沉        if (array[i] > array[target]) {          [array[i], array[target]] = [array[target], array[i]]          target = i;        } else {          break;        }      }    }

复杂度

时间复杂度:O(nlogn)

空间复杂度:O(1)

稳定性

不稳定

四、归并排序

利用归并的思想实现的排序方法。

该算法是采用分治法(Divide and Conquer)的一个非常典型的应用。(分治法将问题分成一些小的问题然后递归求解,而治的阶段则将分的阶段得到的各答案"修补"在一起,即分而治之)。

分割:

归并:

如果需要合并,那么左右两数组已经有序了。

创建一个临时存储数组temp,比较两数组第一个元素,将较小的元素加入临时数组

若左右数组有一个为空,那么此时另一个数组一定大于temp中的所有元素,直接将其所有元素加入temp 

JavaScript怎么实现四种常用排序

function mergeSort(array) {      if (array.length < 2) {        return array;      }      const mid = Math.floor(array.length / 2);      const front = array.slice(0, mid);      const end = array.slice(mid);      return merge(mergeSort(front), mergeSort(end));    }     function merge(front, end) {      const temp = [];      while (front.length && end.length) {        if (front[0] < end[0]) {          temp.push(front.shift());        } else {          temp.push(end.shift());        }      }      while (front.length) {        temp.push(front.shift());      }      while (end.length) {        temp.push(end.shift());      }      return temp;    }

做题时,上面多了删除过程,特别大的例子,时间也可能会超,用下面的方法

function merge(left, right){    let leftLen = left.length, rightLen = right.length;    let i = 0, j = 0;    let temp = new Array(leftLen + rightLen);    for(let cur = 0; cur < leftLen + rightLen; cur++){        // 检查i, j有没有超界        if(i >= leftLen) temp[cur]= right[j++];        else if(j >= rightLen) temp[cur] = left[i++];        else if(left[i] <= right[j]){            temp[cur] = left[i++];        }else{            temp[cur] = right[j++];        }    }    return temp;}

复杂度

时间复杂度:O(nlogn)

空间复杂度:O(n)

稳定性

稳定

看完了这篇文章,相信你对“JavaScript怎么实现四种常用排序”有了一定的了解,如果想了解更多相关知识,欢迎关注编程网行业资讯频道,感谢各位的阅读!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯