我的编程空间,编程开发者的网络收藏夹
学习永远不晚

JavaScript实现基础排序算法的示例详解

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

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

JavaScript实现基础排序算法的示例详解

前言

文本来总结常见的排序算法,通过 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]

到此这篇关于JavaScript实现基础排序算法的示例详解的文章就介绍到这了,更多相关JavaScript排序算法内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

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

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

JavaScript实现基础排序算法的示例详解

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

JavaScript怎么实现基础排序算法

本文小编为大家详细介绍“JavaScript怎么实现基础排序算法”,内容详细,步骤清晰,细节处理妥当,希望这篇“JavaScript怎么实现基础排序算法”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。正文1、冒泡排
2023-07-02

TypeScript十大排序算法插入排序实现示例详解

这篇文章主要为大家介绍了TypeScript十大排序算法插入排序实现示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2023-02-23

TypeScript实现十大排序算法之归并排序示例详解

这篇文章主要为大家介绍了TypeScript实现十大排序算法之归并排序示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2023-02-23

TypeScript十大排序算法之选择排序实现示例详解

这篇文章主要为大家介绍了TypeScript十大排序算法之选择排序实现示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2023-02-23

TypeScript实现十大排序算法之冒泡排序示例详解

这篇文章主要为大家介绍了TypeScript实现十大排序算法之冒泡排序示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2023-02-23

JavaScript实现LRU算法的示例详解

不知道屏幕前的朋友们,有没有和我一样,觉得LRU算法原理很容易理解,实现起来却很复杂。所以本文就为大家整理了一下实现的示例代码,需要的可以参考一下
2023-05-17

Python实现的桶排序算法示例

本文实例讲述了Python实现的桶排序算法。分享给大家供大家参考,具体如下: 桶排序也叫计数排序,简单来说,就是将数据集里面所有元素按顺序列举出来,然后统计元素出现的次数。最后按顺序输出数据集里面的元素。 但是桶排序非常浪费空间, 比如需要
2022-06-04

Java 归并排序算法、堆排序算法实例详解

基本思想:  归并(Merge)排序法是将两个(或两个以上)有序表合并成一个新的有序表,即把待排序序列分为若干个子序列,每个子序列是有序的。然后再把有序子序列合并为整体有序序列。归并排序示例:合并方法:设r[i…n]由两个有序子表r[i…m
2023-05-31

FlutterDart快速排序算法示例详解

这篇文章主要为大家介绍了FlutterDart快速排序算法示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2022-12-09

Java基于分治法实现的快速排序算法示例

本文实例讲述了Java基于分治法实现的快速排序算法。分享给大家供大家参考,具体如下:package cn.nwsuaf.quick;public cl
2023-05-30

Python实现的选择排序算法示例

本文实例讲述了Python实现的选择排序算法。分享给大家供大家参考,具体如下: 选择排序(Selection sort)是一种简单直观的排序算法。它的工作原理是每一次从待排序的数据元素中选出最小(或最大)的一个元素,存放在序列的起始位置,直
2022-06-04

Python实现的计数排序算法示例

本文实例讲述了Python实现的计数排序算法。分享给大家供大家参考,具体如下: 计数排序是一种非常快捷的稳定性强的排序方法,时间复杂度O(n+k),其中n为要排序的数的个数,k为要排序的数的组大值。计数排序对一定量的整数排序时候的速度非常快
2022-06-04

Python实现的归并排序算法示例

本文实例讲述了Python实现的归并排序算法。分享给大家供大家参考,具体如下: 归并排序是建立在归并操作上的一种有效的排序算法,该算法是采用分治法(Divide and Conquer)的一个非常典型的应用。 将已有序的子序列合并,得到完全
2022-06-04

java 中基本算法之希尔排序的实例详解

java 中基本算法之希尔排序的实例详解希尔排序(Shell Sort)是插入排序的一种。也称缩小增量排序,是直接插入排序算法的一种更高效的改进版本。希尔排序是非稳定排序算法。该方法因DL.Shell于1959年提出而得名。希尔排序是把记录
2023-05-31

编程热搜

目录