js的算法-交换排序(冒泡)

news/2024/5/5 18:37:20

交换排序

所谓交换排序,是指根据序列中两个元素关键字的比较结果来对换这两个记录在序列中的位置。基于交换的排序算法很多,本次介绍冒泡排序和快速排序。

冒泡

基本思想

从后往前(或从前往后)两两比较相邻元素的值,若为逆序(即A【i-1】>A【i】),则交换它们;直到序列比较完成。这是第一趟冒泡,结果是将最小的元素交换到待排序列的第一个位置(或者将最大的元素交换到待排序列的最后一个位置),关键字最小的元素如同气泡一样捉奸往上“漂浮”直至“水面”(或关键字最大的元素如石头一样下沉到水底);
下一一趟冒泡是,前一趟确定的最小元素不再参与比较,每次冒泡的结果就是序列中最小元素(或者最大元素)放到了序列的最终位置;循环往复;
这样最多做n-1趟冒泡就能把所有元素排好序。

演示

第一趟:
在这里插入图片描述

第二趟
在这里插入图片描述
后续
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

代码展示

let ary = [5, 9, 3, 1, 2, 8, 4, 7, 6];
let max = ary.length - 1;for (let index = 0; index < max; index++) {// 第一层是循环次数for (let item = max; item > index; item--) {// 第二层比较// 从最后一个元素开始,进行两两比较// 后者(开始位置)比前者小就交换,保证最小的数都交换到了第i个位置上去了if (ary[item] < ary[item - 1]) {let temp = ary[item];ary[item] = ary[item - 1];ary[item - 1] = temp;}}console.log("ary", JSON.stringify(ary));console.log("****");
}
for (let i in ary) {console.log(ary[i]);
}

结果:

ary [1,5,9,3,2,4,8,6,7]
****
ary [1,2,5,9,3,4,6,8,7]
****
ary [1,2,3,5,9,4,6,7,8]
****
ary [1,2,3,4,5,9,6,7,8]
****
ary [1,2,3,4,5,6,9,7,8]
****
ary [1,2,3,4,5,6,7,9,8]
****
ary [1,2,3,4,5,6,7,8,9]
****
ary [1,2,3,4,5,6,7,8,9]
****
1
2
3
4
5
6
7
8
9

写成方法

let ary = [5, 9, 3, 1, 2, 8, 4, 7, 6];
/**** @param {*} ary 数组* @param {*} length 长度* @param {*} isDown 是否降序 默认是降序* @returns*/
// 排序写成方法
function arraySort(ary, length, isDown = false) {// 第一层是循环次数for (let index = 0; index < length - 1; index++) {for (let item = length - 1; item > index; item--) {// 第二层比较// 从最后一个元素开始,进行两两比较// 后者(开始位置)比前者小就交换,保证最小的数都交换到了第i个位置上去了// 判断是否降序let expre = isDown? ary[item] < ary[item - 1]: ary[item] > ary[item - 1];if (expre) {let temp = ary[item];ary[item] = ary[item - 1];ary[item - 1] = temp;}}}return ary;
}
let arr = arraySort(ary, ary.length, true);
console.log("ary", JSON.stringify(ary));

结果:

ary [1,2,3,4,5,6,7,8,9]

性能分析

时间复杂度空间复杂度
最坏情况下时间复杂度为O(n^2); 比较次数为n(n-1)/2;移动次数为3n(n-1)/2;
最好情况下时间复杂度为O(n);比较次数为n-1;移动次数为0;仅使用了常数个辅助单元,所以空间复杂度为O(1 )

http://www.mrgr.cn/p/02336107

相关文章

01_Linux最简单驱动-helloworld

Linux最简单驱动-helloworld 驱动分为四个部分: ​ 头文件 ​ 驱动模块的入口和出口 ​ 声明信息 ​ 功能实现 第一步,包含头文件 #include <linux/init.h> 包含宏定义的头文件 #include <linux/module.h> 包含初始化加载模块的头文件 第二步,驱动模块的入口和出…

《QT实用小工具·四十二》圆形发光图像

1、概述 源码放在文章末尾 该项目实现了图像的发光效果&#xff0c;特别适合做头像&#xff0c;项目demo演示如下所示&#xff1a; 项目部分代码如下所示&#xff1a; import QtQuick 2.7 import QtGraphicalEffects 1.12Item {id: rootwidth: 80height: 80property int ra…

Grid 布局

文章目录 容器属性display 属性grid-template-columns 和 grid-template-rows 属性row-gap、column-gap、gap 属性grid-template-areas 属性grid-auto-flow 属性justify-items、align-items、place-items 属性justify-content、align-content、place-content 属性grid-auto-col…

KNN算法思想与Python实现

古语说得好,物以类聚,人以群分;近朱者赤,近墨者黑。这两句话的大概意思就是,你周围大部分朋友是什么人,那么你大概率也就是这种人,这句话其实也就是K最近邻算法的核心思想。kNN(k- Nearest Neighbor)法即k最邻近法,最初由 Cover和Hart于1968年提出,是一个理论上比较…

数据结构练习-算法与时间复杂度

----------------------------------------------------------------------------------------------------------------------------- 1. 设n是描述问题规模的非负整数&#xff0c;下列程序段的时间复杂度是( )。 x0;while(n>(x1)*(x1)xx1; A.O(logn) B.O(n^(1/2)) C.O(n)…

递归神经网络(RNN)在AI去衣技术中的深度应用

在人工智能&#xff08;AI&#xff09;技术飞速发展的今天&#xff0c;图像处理和计算机视觉领域不断取得新的突破。其中&#xff0c;AI去衣技术作为一个具有挑战性的研究方向&#xff0c;引起了广大研究者和公众的关注。递归神经网络&#xff08;RNN&#xff09;作为深度学习的…

HarmonyOS 应用生命周期有哪些? 按返回键会调用哪些生命周期?

UIAbility 生命周期:onCreate :页面初始化,变量定义,资源加载。 onWindowStageCreate:设置 UI 界面加载、设置 WindowStage 的事件订阅。 onForeground:切换至前台,申请系统需要的资源,或者重新申请在 onBackground()中释放的资源。 onBackground:切换至后台,释放 U…

(007)Blender 根据顶点组分离模型

1.选中模型&#xff0c;并且进入【3D视图】【编辑模式】&#xff1a; 2.选择顶点组&#xff1a; 3.分离选中项&#xff1a;

DRF之过滤 排序 分页

DRF之过滤 排序 分页使用【过滤 排序 分页】都需要在继承了GenericAPIView的视图类下使用 并指定类属性【queryset 和 serializer_class】【一】过滤 # 所有过滤类都继承 【BaseFilterBackend】 from rest_framework.filters import BaseFilterBackend【1】drf自带的过滤 # 导入…

图文结合手把手教你创建SpringCloud项目

前言 什么是SpringCloud? Spring Cloud 是一系列框架的有序集合,它利用 Spring Boot 的开发便利性简化了分布式系统的开发,比如服务注册、服务发现、网关、路由、链路追踪等。Spring Cloud 并不是重复造轮子,而是将市面上开发得比较好的模块集成进去,进行封装,从而减少了…

redis中的缓存穿透问题

缓存穿透 缓存穿透问题&#xff1a; 一般请求来到后端&#xff0c;都是先从缓存中查找数据&#xff0c;如果缓存中找不到&#xff0c;才会去数据库中查询数据。 而缓存穿透就是基于这一点&#xff0c;不断发送请求查询不存在的数据&#xff0c;从而使数据库压力过大&#xff…

ubuntu无法用快捷键启动终端(CTRL+AIT+T)

我的电脑不知道安装什么东西之后&#xff0c;就不能用快捷键&#xff08;CTRLAITT&#xff09;打开终端了 只能在文件夹内&#xff0c;点击鼠标右键选择终端&#xff0c;然后打开终端 一直这么用了几个月&#xff0c;今天实在受不了了&#xff0c;所以解决此问题 本文参考文章…

力扣-118. 杨辉三角

1.题目介绍 题目地址(118. 杨辉三角 - 力扣(LeetCode)) https://leetcode.cn/problems/pascals-triangle/ 题目描述 给定一个非负整数 numRows,生成「杨辉三角」的前 numRows 行。 在「杨辉三角」中,每个数是它左上方和右上方的数的和。 示例 1: 输入: numRows = 5 输出: …

IDEA中springboot项目编译两次的问题

原因:因为在导入项目的之后,项目无法运行,问题1:显示缺少org.springbootframe的依赖,不知道怎么解决,网上搜了个方法,就是勾选下图的选项,意思是把build操作由IDEA交给Maven,勾选之后确实可以启动项目了但是后面在执行Mybatis时,问题2:我发现无论如何都会报一个唯一…

深入刨析 mysql 底层索引结构B+树

文章目录 前言一、什么是索引&#xff1f;二、不同索引结构对比2.1 二叉树2.2 平衡二叉树2.3 B-树2.4 B树 三、mysql 的索引3.1 聚簇索引3.2 非聚簇索引 前言 很多人看过mysql索引的介绍&#xff1a;hash表、B-树、B树、聚簇索引、主键索引、唯一索引、辅助索引、二级索引、联…

计算机为什么需要中断?

// generated by ChatGPT-3.5 & hk416hasu中断是计算机系统中一种重要的机制,它允许系统在执行过程中临时中止当前任务,转而处理其他优先级更高或更紧急的任务,然后再返回原来的任务。以下是一些计算机需要中断的原因:1. 响应外部事件:计算机系统需要能够响应各种外部…

SpringCloud之负载均衡Ribbon

Ribbon 是一个客户端负载均衡工具&#xff0c;主要功能是将面向服务的Rest模板&#xff08;RestTemplate&#xff09;请求转换成客户端负载均衡的服务调用。通过Ribbon&#xff0c;开发人员可以在客户端实现请求的负载均衡&#xff0c;而无需单独部署负载均衡器。Ribbon支持多…

Linux实现文件共享

#nfs-utils、rpcbind 软件包来提供 NFS 共享服务 #客户端创建共享文件夹&#xff1a; nmcli c reload nmcli c up ens160 systemctl stop firewalld systemctl disable firewalld rpm -q nfs-utils rpcbind #查看是否安装 systemctl enable rpcbind systemctl enable nfs…

OpenHarmony网络协议通信—libevent [GN编译] - 事件通知库

libevent主要是用C语言实现了事件通知的功能 下载安装 直接在OpenHarmony-SIG仓中搜索libevent并下载。 使用说明 以OpenHarmony 3.1 Beta的rk3568版本为例 库代码存放路径&#xff1a;./third_party/libevent 修改添加依赖的编译脚本 在/developtools/bytrace_standard/…

【爆款推荐】初中中考阅读理解难题一网打尽!句子结构深度解析+答案揭秘,助你轻松冲刺高分!-011

PDF格式公众号回复关键字:ZKYDT011原文1 The writer lost her father at the age of four, didn’t she? 解析 1 The writer 这位作者, lost 失去, her father 她的父亲, at the age of four 在4岁的时候, didn’t she?不是吗? 这位作家四岁时失去了父亲,不是吗? 2 Eve…