JavaScript 实现 -- 快速排序

2023-11-12

快速排序

快速排序算法是在分治算法基础上设计出来的一种排序算法,和其它排序算法相比,快速排序算法具有效率高、耗费资源少、容易实现等优点。

快排原理

选择一个基准数,通过一次排序将待排序数组分割成两个分区;其中分区的所有数据都比另外一分区的所有数据都要小。然后对分区的数据进行递归,重复上述操作以此达到整个数据变成有序序列。

代码实现

	Array.prototype.quickSort = function(){
	    const rec = (arr) => {
	        if(arr.length === 1 || arr.length === 0){ return arr;}
	        const left = [];
	        const right = [];
	        const mid = arr[0];
	        for(let i = 1; i < arr.length; i++){
	            if(arr[i] > mid){
	                right.push(arr[i]);
	            }else{
	                left.push(arr[i]);
	            }
	        }
	        return [...rec(left), mid, ...rec(right)];
	    };
	    const res = rec(this);
	    //将res拷贝到this
	    res.forEach( (n, i) => { this[i] = n; });
	} 
	
	// 测试用例
	const arr = [1,0,9,4,5];
	arr.quickSort();

快排过程

在这里插入图片描述
第一次代码执行完,未递归时,left数组为空,递归时直接返回;

right数组长度大于1,进行递归调用;

在这里插入图片描述
right数组递归后,left数组长度大于1,进行递归调用;

right数组为空,递归时直接返回;

在这里插入图片描述
left数组递归后,left数组为空,递归时直接返回;

right数组长度为1,排序完成;

在这里插入图片描述

时间复杂度

快速排序递归的时间复杂度为O(logN),分区的时间复杂度为O(N),所以其时间复杂度为O(n*logN);

算法稳定性

快速排序是不稳定的算法;

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

JavaScript 实现 -- 快速排序 的相关文章

随机推荐

  • [RN] windows7 安装 Realm Studio 后,打开报错 A JavaScript error occurred in the main process...

    windows7 安装 Realm Studio 后 打开报错 报错如下 A JavaScript error occurred in the main process Uncaught Exception Error The specif
  • 为什么说Java只有值传递

    为什么说Java只有值传递 1 值传递概念 2 引用传递概念 3 Java只有值传递 没有引用传递 1 值传递概念 方法调用时 会创建副本 传递的是值的副本 也就是说传递后就不相关了 2 引用传递概念 方法调用时 不会创建副本 传递的是引用
  • 树莓派内核编译

    一 概述 树莓派的github主页 https github com raspberrypi 里面包含了linux源码 交叉编译工具链等内容 对于我们要用到的有两个仓库 https github com raspberrypi linux
  • QT笔记-QTableWidget点击表格头,显示菜单项

    1 添加控件 2 示例源码 h private slots void OnClickHeader int head void OnClickMenu QAction action cpp void Textdemo OnInitTableW
  • [css3] 动画案例---会呼吸的圆

  • Python 源代码缩进格式化工具

    前言 昨天在跟小伙伴聊天 当他谈起自己正在做的项目时 一脸愁容 他吐槽道 该项目的 Python 代码库由多个人共同维护 由于每个人使用的编辑器不同 每个人的编码风格也不同 最终导致了 代码的缩进千奇百怪 有缩进 2 个空格的 有缩进 4
  • 《Linux0.11源码解读》理解(四) head之重新设置IDT/GDT

    上节提到 现在cs ip指向0地址 此处存储着作为操作系统核心代码的system模块 是由head s和 main c以及后面所有源代码文件编译链接而成 head s 以下简称head 紧挨着main c 我们先执行head 重新设置内核栈
  • 带外数据

    定义带 外 数据 想 像一下在银行人们排起队等待处理他们的帐单 在这个队伍中每个人最后都会移到前面由出纳员进行服务 现在想像一下一个走入银行 越过整个队伍 然后用枪抵 住出纳员 这个就可以看作为带 外 数据 这个强盗越过整个队伍 是因为这把
  • 第六天哈希表

    哈希表 哈希表是根据关键码的值而直接进行访问的数据结构 其实呢 数组就是一张哈希表 其中 关键码就是索引下标 然后通过下标访问数组中的元素 什么时候想到用哈希法 当我们遇到了要快速判断一个元素是否出现集合里的时候 就要考虑哈希法 这 要枚举
  • 平衡球迷宫教程(一)

    平衡球迷宫教程 一 今天分享一个简单的小游戏 平衡球迷宫 这个游戏简单易上手 非常适合刚刚接触unity人员作为基础练习 一 建立一个道路 可以让小球在上面滚动 这里我建立的道路是用3D物体中cube建立的起初用的地板plane 但是后期更
  • ChatGPT专业应用:生成奖项方案

    正文共 925 字 阅读大约需要 4 分钟 人力资源等必备技巧 您将在4分钟后获得以下超能力 生成奖项方案 Beezy评级 A级 经过寻找和一段时间的学习 一部分人能掌握 主要提升效率并增强自身技能 推荐人 Kim 编辑者 Yolanda
  • C#文件读写

    C 的IO类库提供了丰富的IO操作 下面我来总结一下其IO类库提供的一些操作文件系统的方法 一 操作驱动器 C 用DriveInfo来操作驱动器 1 创建对象 a 我们可以通过静态方法DriveInfo GetDrives 来获取所有的Dr
  • 掌握VS2010调试 -- 入门指南

    1 导言 在软件开发周期中 测试和修正缺陷 defect defect与bug的区别 Bug是缺陷的一种表现形式 而一个缺陷是可以引起多种Bug的 的时间远多于写代码的时间 通常 debug是指发现缺陷并改正的过程 修正缺陷紧随debug之
  • vue 拖拽功能样式优化

    拖拽需求完成之后 发现拖拽的过程中很丑 放下的时候光标处也是禁止 虽然说功能不影响 但是用户体验还是不太好 不够专业 所以请做以下优化 1 把需要拖拽的图标加上可拖拽属性 div 需要拖拽的元素 div draggable true 2 在
  • 数据库表关系设计

    数据库表设计 设计原则 考虑问题时 一定要站在一头考虑 常用的关联关系 主外键关联 主外键设计原则 我自己的主键可以充当别人的外键 核心知识 主键不能重复的 外键可以重复 一对一 业务场景 用户 user 表与用户详情表 user info
  • sql如何查看数据库表的关联关系?

    SHOW CREATE TABLE 表名 不管是Navicat还是MySQL Workbench 要查询表的创建sql语句的话 在新建查询中执行以下sql SHOW CREATE Table BinLots 执行之后 Create Tabl
  • 在Jenkins管道中添加Webhook

    你有没有尝试过在Jenkins中添加GitHub webhook 在这篇博客中 我将演示在您的管道中添加webhook的最简单方法 首先 什么是webhook webhook的概念很简单 webhook是一个HTTP回调 当通过HTTP P
  • 【简单题】(2018)第九届蓝桥杯省赛 C/C++ A组(第一题、第二题)

    第一题 题目 标题 分数1 1 1 2 1 4 1 8 1 16 每项是前一项的一半 如果一共有20项 求这个和是多少 结果用分数表示出来 类似 3 2当然 这只是加了前2项而已 分子分母要求互质 注意 需要提交的是已经约分过的分数 中间任
  • Linux最全解压命令(*.tar *tar.gz *.gz *.tar.bz2 *.bz2 *tar.xz *.xz *tar.Z *.Z *.rar *.zip *.7z *.7za)

    压缩解压命令 这里重点介绍tar命令 它是一个打包程序 它可 以调用其它的命令 如 gzip bzip2 除此之外还有 rar zip命令 注 无特殊说明 代表文件夹 代表次一级文件夹 代表文件 一 tar 用法 tar 选项 FILE c
  • JavaScript 实现 -- 快速排序

    文章目录 快速排序 快排原理 代码实现 快排过程 时间复杂度 算法稳定性 快速排序 快速排序算法是在分治算法基础上设计出来的一种排序算法 和其它排序算法相比 快速排序算法具有效率高 耗费资源少 容易实现等优点 快排原理 选择一个基准数 通过