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

JavaScript怎么实现基础排序算法

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

北京

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

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

看不清楚,换张图片

免费获取短信验证码

JavaScript怎么实现基础排序算法

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

正文

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怎么实现基础排序算法”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注编程网行业资讯频道。

免责声明:

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

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

JavaScript怎么实现基础排序算法

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

下载Word文档

猜你喜欢

JavaScript怎么实现基础排序算法

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

python常见排序算法基础教程

前言:前两天腾讯笔试受到1万点暴击,感觉浪费我两天时间去牛客网做题……这篇博客介绍几种简单/常见的排序算法,算是整理下。 时间复杂度 (1)时间频度一个算法执行所耗费的时间,从理论上是不能算出来的,必须上机运行测试才能知道。但我们不可能也没
2022-06-04

用JavaScript实现的七种排序算法

这篇文章主要讲解了“用JavaScript实现的七种排序算法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“用JavaScript实现的七种排序算法”吧!目录前言冒泡排序基础算法第二种写法是在
2023-06-20

Java怎么实现排序算法Timsort

这篇文章主要介绍“Java怎么实现排序算法Timsort”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Java怎么实现排序算法Timsort”文章能帮助大家解决问题。背景Timsort 是一个混合、
2023-07-02

python堆排序算法怎么实现

堆排序算法的实现步骤如下:构建最大堆(Max Heap):首先将待排序的序列构建成一个最大堆。从最后一个非叶子节点开始,依次将当前节点与其子节点进行比较,如果当前节点的值小于子节点的值,则将两者交换位置,并继续比较下一个子节点,直到当前节点
2023-10-26

TypeScript十大排序算法插入排序怎么实现

今天小编给大家分享一下TypeScript十大排序算法插入排序怎么实现的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。一. 插
2023-07-05

php怎么实现冒泡排序算法

php实现冒泡排序算法的方法:【for ($i=0 ; $i<count($arr) ; $i++) {$data = '';for ($j=$i ; $j < count($arr)-1 ; $j++) {if ($arr[$..】。
2017-10-26

C++归并排序算法怎么实现

这篇文章主要介绍“C++归并排序算法怎么实现”,在日常操作中,相信很多人在C++归并排序算法怎么实现问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”C++归并排序算法怎么实现”的疑惑有所帮助!接下来,请跟着小编
2023-06-26

go快速排序算法怎么实现

快速排序(Quick Sort)是一种高效的排序算法,它的基本思想是选择一个基准元素,通过一趟排序将数组分成两部分,其中一部分的所有元素都比基准元素小,另一部分的所有元素都比基准元素大。然后递归地对这两部分进行排序,以达到整个数组有序的目的
2023-10-26

java睡眠排序算法怎么实现

本篇内容主要讲解“java睡眠排序算法怎么实现”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“java睡眠排序算法怎么实现”吧!先看下图:真是厉害啊,这排序, 既有多线程,又有排序,还有lambd
2023-06-29

Java十大排序算法怎么实现

本篇内容介绍了“Java十大排序算法怎么实现”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!排序算法的稳定性: 假定在待排序的记
2023-06-29

Golang怎么实现常见排序算法

这篇文章主要介绍“Golang怎么实现常见排序算法”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Golang怎么实现常见排序算法”文章能帮助大家解决问题。五种基础排序算法对比五种基础排序算法对比1、
2023-06-30

Python冒泡排序算法怎么实现

今天小编给大家分享一下Python冒泡排序算法怎么实现的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。1. 算法描述冒泡排序(
2023-07-02

Java常见排序算法怎么实现

本文小编为大家详细介绍“Java常见排序算法怎么实现”,内容详细,步骤清晰,细节处理妥当,希望这篇“Java常见排序算法怎么实现”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。汇总:1. 冒泡排序每轮循环确定最值;
2023-06-29

python快速排序算法怎么实现

快速排序是一种常用的排序算法,其算法思想是通过递归地将数组分为较小和较大的两个子数组,然后不断重复这个过程,直到整个数组有序。下面是用Python实现的快速排序算法:```pythondef quick_sort(arr):if len(a
2023-08-15

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录