目录

十大排序算法分类​编辑

冒泡排序

算法步骤:

 动图演示:

性能分析:

代码实现(Java):

快速排序(挖坑法)

算法步骤:

动图演示:

性能分析:

代码实现(Java):


十大排序算法分类

本篇分享十大排序算法中的 需要进行交换操作的冒泡排序快速排序 , 其余算法也有介绍噢(努力赶进度中,后续会添加上)
 

冒泡排序

冒泡排序是一种非常直观的排序算法,遍历数组,每次比较两个元素,如果后者比前者小则交换位置 ,重复的进行直至没有再需要交换,说明该数组排序完成。冒泡排序的 名字由来是因为越小的元素会经过交换慢慢"浮"到数组的顶端。

算法步骤:

核心逻辑

  • 外层循环控制轮数,共进行 n-1 轮遍历,n 为数组长度。
  • 每轮内层循环比较相邻元素 arr[j] 和 arr[j+1],若前者较大则交换。
  • 每轮结束后,当前未排序部分的最大值会“冒泡”到正确位置(数组末尾)。

优化方法

  • 提前终止:引入boolean变量,如果在某轮内循环未发生交换,说明数组有序,可直接结束排序
  •  减少遍历范围:每轮外层循环后,数组末尾已有序,内层循环无需再比较已排序部分。

终止条件

  •  外层循环完成n - 1次遍历,或boolean = false

 动图演示:

性能分析:

时间复杂度

  •  最好情况:数组已经有序,此时只需要遍历一次,时间复杂度 O(n)
  •  最坏情况:数组完全倒序,此时需要遍历n - 1次,每次遍历都需要进行n - i 次 比较可能的交换(i为当前遍历次数),因此时间复杂度为O(n^2)
  •   平均情况:时间复杂度为O(n^2)     

空间复杂度

  • 仅需常数级额外空间 因此空间复杂度为O(1)

稳定性:

  • 稳定排序(相等元素不会交换位置)

代码实现(Java):

/*** 冒泡排序算法实现(升序排序)* @param arr 待排序的整型数组*/
public void bubbleSort(int[] arr) {// 获取数组长度int n = arr.length;// 布尔变量用于    boolean swapped;// 外层循环:控制排序轮数(最多需要 n-1 轮)for (int i = 0; i < n - 1; i++) {// 每轮开始前初始化交换标志为 falseswapped = false;// 内层循环:比较相邻元素并交换// 每轮结束后,最大的元素会"冒泡"到数组末尾,所以比较范围逐渐缩小for (int j = 0; j < n - i - 1; j++) {// 如果前一个元素大于后一个元素(升序排序)if (arr[j] > arr[j + 1]) {// 交换相邻元素int temp = arr[j];arr[j] = arr[j + 1];arr[j + 1] = temp;// 标记发生了交换swapped = true;}}// 优化:如果本轮没有发生任何交换,说明数组已经有序,提前结束排序if (!swapped) {break;}}
}

快速排序(挖坑法)

快速排序核心就是选择一个基准值(就是一个作参照的数),然后将数组分成左右两部分,左边是比基准值小的元素。右边是比基准值大的元素。 然后递归地对左右两部分继续进行这个过程,最终整个数组有序

快速排序是通过一次分区就定位一个元素的最终位置,并递归处理两侧子数组

算法步骤:

   核心逻辑

  1. 首先设定一个基准值 (通常是第一个数字/最后一个数字),通过该基准值将数组分成左右两部分。
  2. 分区(partition):将所有小于基准值的元素移到基准值左边,大于的移到右边

  3. 递归排序:对左右两个子数组递归进行上述过程

  4. 概括来说为 挖坑填数 + 分治法

 优化方法

  • 采用三数取中法(取左、中、右三个位置的中间值作为基准值)
  • 如果分区后子数组长度小于阈值(如 10)时,直接改用插入排序,减少了递归的开销

  终止条件

  • 当left >= right (起始索引大于等于结束索引,子数据长度 <= 1),终止当前递归(说明该子数组已有序)
  • 所有子数组均完成分区和排序时,整个数组即有序

动图演示:

(借用大佬的动图)

性能分析:

时间复杂度

  • 时间性能你取决于递归的深度
  • 最好情况:二叉树几乎平衡时,也就是数组划分的比较均匀(基准值位于中间)。,递归次数最少,要log2N 次。递归过程中需要对i,j下标一起扫描数组,所以总体时间复杂度时O(N*log2N)
  • 最坏情况二叉树极度不平衡 ,整体时间复杂度达到 (N²)

空间复杂度:

  • 空间性能取决于递归消耗的栈空间
  • 最好情况:已经分析过,需要递归logzN次,空间复杂度为O(logzN)
  • 最坏情况已经分析过,需要递归N-1次,空间复杂度为O(N)

稳定性:

  • 不稳定 

代码实现(Java):

public static void quickSort(int[] array) {quick(array, 0, array.length - 1);}private static void quick(int[] array, int start, int end) {// 取大于号,防止 start > endif (start >= end) {return;}int pivot = pirtiton1(array, start, end);quick(array, start, pivot - 1);quick(array, pivot + 1, end);}// 挖坑法private static int pirtiton1(int[] array, int left, int right) {int tmp = array[left];while (left < right) {// 为什么判断条件加等号,// 用int[] arr = {5, 7, 3, 1, 4, 9, 6, 5}测试while (left < right && array[right] >= tmp) {right--;}array[left] = array[right];while (left < right && array[left] <= tmp) {left++;}// 将找到的大于基准值的元素填入右边的"坑"array[right] = array[left];}// 将基准值放入最后的"坑"中(此时left == right)array[left] = tmp;return left;}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/bicheng/90018.shtml
繁体地址,请注明出处:http://hk.pswp.cn/bicheng/90018.shtml
英文地址,请注明出处:http://en.pswp.cn/bicheng/90018.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

2023 年 5 月青少年软编等考 C 语言八级真题解析

目录 T1. 道路 思路分析 T2. Rainbow 的商店 思路分析 T3. 冰阔落 I 思路分析 T4. 青蛙的约会 思路分析 T1. 道路 题目链接:SOJ D1216 N N N 个以 1 ∼ N 1 \sim N 1∼N 标号的城市通过单向的道路相连,每条道路包含两个参数:道路的长度和需要为该路付的通行费(以金币的数…

【vue-4】深入理解 Vue 3 中的 v-for 指令

Vue.js 作为现代前端框架的代表之一&#xff0c;其模板指令系统提供了强大的数据绑定和渲染能力。其中&#xff0c;v-for 指令是 Vue 中最常用且最重要的指令之一&#xff0c;它允许我们基于数据源循环渲染元素或组件。在 Vue 3 中&#xff0c;v-for 保留了一贯的简洁语法&…

《R for Data Science (2e)》免费中文翻译 (第1章) --- Data visualization(1)

写在前面 本系列推文为《R for Data Science (2)》的中文翻译版本。所有内容都通过开源免费的方式上传至Github&#xff0c;欢迎大家参与贡献&#xff0c;详细信息见&#xff1a; Books-zh-cn 项目介绍&#xff1a; Books-zh-cn&#xff1a;开源免费的中文书籍社区 r4ds-zh-cn …

界面组件DevExpress WPF中文教程:Grid - 如何完成节点排序和移动?

DevExpress WPF拥有120个控件和库&#xff0c;将帮助您交付满足甚至超出企业需求的高性能业务应用程序。通过DevExpress WPF能创建有着强大互动功能的XAML基础应用程序&#xff0c;这些应用程序专注于当代客户的需求和构建未来新一代支持触摸的解决方案。 无论是Office办公软件…

【Prometheus+Grafana篇】监控通过Keepalived实现的MySQL HA高可用架构

&#x1f4ab;《博主主页》&#xff1a;    &#x1f50e; CSDN主页__奈斯DB    &#x1f50e; IF Club社区主页__奈斯、 &#x1f525;《擅长领域》&#xff1a;擅长阿里云AnalyticDB for MySQL(分布式数据仓库)、Oracle、MySQL、Linux、prometheus监控&#xff1b;并对…

k8s:利用kubectl部署postgis:17-3.5

1.离线环境CPU:Hygon C86 7285 32-core Processor 操作系统&#xff1a;麒麟操作系统 containerd&#xff1a;1.7.27 Kubernetes:1.26.12 KubeSphere:4.1.2 kubekey&#xff1a;3.1.10 Harbor:2.13.1 Postgis:17-3.52.创建并执行postgresql-headless.yaml2.1创建apiVersion: v1…

Mysql(存储过程)

目录 介绍 特点 存储过程创建 系统变量(不重要) 用户变量 局部变量 if 判断 参数&#xff08;in, out, inout) case while repeat loop 游标和条件处理程序-handler 存储函数 为了防止以后忘记&#xff0c;反复去看视频浪费时间&#xff0c;特写一篇 介绍 存储过程…

Effective Python 第14条: 用sort方法的key参数来表示复杂的排序逻辑

一、引言&#xff1a;Python排序功能的重要性 在Python开发中&#xff0c;排序功能是一个常见的需求。无论是处理数据、优化算法&#xff0c;还是提升用户体验&#xff0c;排序都是不可或缺的一部分。Python的列表内置了sort方法&#xff0c;提供了灵活的排序功能。然而&#…

react+antd 可拖拽模态框组件

DraggableModal 可拖拽模态框组件使用说明 概述 DraggableModal 是一个基于 dnd-kit/core 实现的可拖拽模态框组件&#xff0c;允许用户通过拖拽标题栏来移动模态框位置。该组件具有智能边界检测功能&#xff0c;确保模态框始终保持在可视区域内。 功能特性 ✅ 可拖拽移动&…

MySQL的基本操作及相关python代码

下面为你介绍 MySQL 的基本操作,以及对应的 Python 代码实现。我会先介绍 SQL 基本操作,再展示如何用 Python 连接 MySQL 并执行这些操作。 一、MySQL 基本操作(SQL 语句) 1. 连接数据库 bash mysql -u root -p2. 创建数据库 sql CREATE DATABASE testdb;3. 使用数据…

Armbian(斐讯N1)安装xfce桌面以及远程环境

安装xfce桌面以及vncserver(远程连接) 安装xfce桌面 apt-get install xfce4 xfce4-goodies xorg dbus-x11 x11-xserver-utils ubuntu的安装gdm3&#xff0c; apt install gdm3 debian安装lightdm。 apt install lightdm 安装vnc server apt-get install tightvncserver 中文字体…

【Oracle】Oracle 11g打补丁时遇到opatch apply命令无法识别

⚙️ 1. 使用完整路径执行命令 问题原因&#xff1a;若未将$ORACLE_HOME/OPatch加入系统PATH环境变量&#xff0c;直接输入opatch apply会因系统无法定位命令而报错。 解决方案&#xff1a; 改用绝对路径执行&#xff1a; $ORACLE_HOME/OPatch/opatch apply例如&#xff1a; /u…

单例模式详细讲解

一.定义单例模式是一种创建型设计模式&#xff0c;确保一个类只有一个实例&#xff0c;并提供一个全局访问点特点&#xff1a;1.构造函数和析构函数私有化2.禁用拷贝构造函数和赋值运算符重载&#xff08;delete&#xff09;3.利用静态成员函数和静态成员变量来给外界提供访问二…

KORGym:评估大语言模型推理能力的动态游戏平台

KORGym&#xff1a;评估大语言模型推理能力的动态游戏平台 现有评估基准多受领域限制或 pretraining 数据影响&#xff0c;难以精准测LLMs内在推理能力。KORGym平台应运而生&#xff0c;含50余款游戏&#xff0c;多维度评估&#xff0c;本文将深入解析其设计、框架、实验及发现…

ISPDiffuser文章翻译理解

ISPDiffuser: Learning RAW-to-sRGB Mappings with Texture-Aware Diffusion Models and Histogram-Guided Color Consistency翻译 Type: Conference paper Author: Yang Ren1,4, Hai Jiang1,4, Menglong Yang1,2,†, Wei Li1,2, Shuaicheng Liu3,4,† Select: ⭐️⭐️⭐️⭐…

C++线程池执行步骤分析,总结线程池流程

线程池流程总结&#xff1a;1、构造函数中创建线程&#xff0c;并添加到线程池&#xff08;构造函数返回时&#xff0c;线程自动启动&#xff0c;并停在等待wait&#xff1a;从线程池取出一个任务处&#xff09;&#xff1b; 2、主线程中添加任务&#xff0c;到任务队列。并用“…

Java 通过 HttpURLConnection发送 http 请求

问题&#xff1a; 在调试 kill 接口的时候&#xff0c;对方的服务用的是 Django RestFramework 框架提供的接口&#xff0c;用 python 请求时得到的内容如下&#xff1a; ➜ ~ python3 test.py <Response [200]> "true" // 对应的代码是 print(response, r…

【PTA数据结构 | C语言版】列出连通集

本专栏持续输出数据结构题目集&#xff0c;欢迎订阅。 文章目录题目代码题目 给定一个有 n 个顶点和 m 条边的无向图&#xff0c;请用深度优先遍历&#xff08;DFS&#xff09;和广度优先遍历&#xff08;BFS&#xff09;分别列出其所有的连通集。假设顶点从 0 到 n−1 编号。…

GoLang教程005:switch分支

3.4 Switch分支 在 GoLand&#xff08;其实是 JetBrains 开发的 Go 编程语言 IDE&#xff09;中&#xff0c;switch 是 Go 语言&#xff08;Golang&#xff09; 的一个重要控制结构&#xff0c;用于替代多个 if-else 语句。 ✅ 特点说明特性说明自动 breakGo 的 switch 语句默认…

uniapp相关地图 API调用

目录 一、 注意事项&#xff1a; manifest.json需增加配置 二、获取用户收货地址 [uni.chooseAddress] 三、获取当前的地理位置、速度 [uni.getLocation] 四、打开地图选择位置、查看位置(导航) [uni.chooseLocation] [uni.openLocation] 五、使用腾讯地图逆地址解析接口实…