数据结构排序算详解(动态图+代码描述)
目录
1、直接插入排序(升序)
2、希尔排序(升序)
3、选择排序(升序)
方式一(一个指针)
方式二(两个指针)
4、堆排序(升序)
5、冒泡排序(升序)
6、快速排序 (升序)
方式一(Hoare方法)
方式二(挖坑法)
快排改进算法(三数取中)
7、归并排序
8、总结
1、直接插入排序(升序)
描述:对于一个数组i从第二个数据开始比较,j=i-1,j<0停止,每次i下标元素放到临时变量tmp中与j下标比较,如果大于j下标,tmp还放回原位置,i和j都加加,如果小于j下标,j--,直到找到大于j下标元素,tmp放到j+1下标
时间复杂度:最好情况下O(n),最坏情况O(n^2)
空间复杂度:O(1)
//直接插入排序
//时间复杂度:最好情况下O(n),最坏情况O(n^2)
public class Test1 {public static void sort(int []array){for (int i = 1; i <array.length ; i++) {int tmp=array[i];int j = i-1;for (; j >=0 ; j--) {if(tmp<array[j])array[j+1]=array[j];else break;}array[j+1]=tmp;}}
}
2、希尔排序(升序)
描述:我们先对数组中数据分组,数组长度即位N,具体先分为gap组,gap=N/2,N/4,N/8.....1。然后对每一组直接插入排序。
时间复杂度:O(n*log2(N)),空间复杂度:O(1)
每种颜色一组例如:
例如:
public static void ShellSort(int [] array){int gap=array.length;//10while (gap>1){gap=gap/2;Sort(array,gap);//5,2,1}}private static void Sort(int [] array,int gap){for (int i = gap; i <array.length ; i++) {int tmp=array[i];int j = i-gap;//每组直接插入排序for (; j >=0 ; j=j-gap) {if (tmp<array[j])array[j+gap]=array[j];else break;}array[j+gap]=tmp;}
3、选择排序(升序)
方式一(一个指针)
描述: 每次找最小值下标,与i下标交换,i++
空间复杂度:O(1),时间复杂度:O(N^2)
public static void selcetSort(int [] array){for (int i = 0; i <array.length ; i++) {int min=i;//记录每次最小值下标for (int j = i+1; j <array.length ; j++)if (array[j]<array[min])min=j;swap(min,i,array);}}private static void swap(int i ,int j,int [] array){int tmp=array[i];array[i]=array[j];array[j]=tmp;}
方式二(两个指针)
思路:left,right指向数组的两端,每次遍历找到最大值和最小值,分别赋值给lefgt和right
public static void selectSort2(int[] array) {int left = 0;int right = array.length-1;int i;while (left < right) {//i minIndex maxIndexint minIndex=left,maxIndex=right;i=left+1;for(;i<right;i++){if (array[i]<=array[minIndex])minIndex=i;if (array[i]>array[maxIndex])maxIndex=i;}swap(left,minIndex,array);swap(right,maxIndex,array);left++;right--;}}private static void swap(int i ,int j,int [] array){int tmp=array[i];array[i]=array[j];array[j]=tmp;}
4、堆排序(升序)
思路:先创建成大根堆,每次排序把根节点与最后位置元素交换后向下调整,下一次根节点与end-1下标交换后向下调整,直到end<0;结束
public static void HeapSort(int[]array){creatHeap(array.length,array);//创建大根堆int end=array.length-1;while (end>0){swap(end,0,array);signHeap(0,end,array);//向下调整不挑最后一个所以后减减end--;}}public static void creatHeap(int end,int [] array){int preheap;//每次的根节点for ( preheap=(end-1-1)/2;preheap>=0;preheap--){signHeap(preheap,end, array);}}//向下调整为大根堆为例private static void signHeap(int preheap,int end,int [] array){//向下调整int child=preheap*2+1;//preheap左子树下标while (child<end){if(child+1<end&&array[child]<array[child+1])child++;//现在child指向孩子节点的最大值if (array[preheap]<array[child]){swap(preheap,child,array);preheap=child;child=child*2+1;}else break;}}private static void swap(int i ,int j,int [] array){int tmp=array[i];array[i]=array[j];array[j]=tmp;}
5、冒泡排序(升序)
时间复杂度:O(N^2),空间复杂度O(1)
public static void bubbleSort(int [] array){for (int i = 0; i < array.length-1; i++) {boolean flag=false;for (int j = 0; j < array.length-1; j++) {if (array[j]>array[j+1]){swap(j,j+1,array);flag=true;}}if (flag==false)break;}}private static void swap(int i ,int j,int [] array){int tmp=array[i];array[i]=array[j];array[j]=tmp;}
6、快速排序 (升序)
方式一(Hoare方法)
描述:
每次都是最左边的元素是基点,从左边往右找到比基点大的跟从右往左找到比基点小的交换,最后left和right交点和基点交换,这样排完一次后交点左边比交点值小,后边大,分左右递归在排
时间复杂度:O(Nlog2(N)),空间复杂度O(log2(N))
public static void quick(int [] array){int start=0,end=array.length-1;quickSort(array,start,end);}private static void quickSort(int [] array,int start,int end){if(start>=end)return;int mid=sort(array,start,end);quickSort(array,start,mid-1);quickSort(array,mid+1,end);}private static int sort(int [] array,int left,int right){int tmp=array[left];//基准int i=left;//先写右的right--,否则一遍走到left==right后与i下标交换的那一次且仅仅一次将会不有序while (left<right) {while (left < right && tmp <=array[right]) right--;//找到比tmp小的数while (left < right && tmp >= array[left]) left++;//找到比tmp大的数swap(right, left, array);}swap(left,i,array);return left;//left==right==mid}private static void swap(int i ,int j,int [] array){int tmp=array[i];array[i]=array[j];array[j]=tmp;}
方式二(挖坑法)
思想:每次都是最左边的元素是基点,保存基点下标,此处就是一个坑,从右往左找到比基点小的放到基点下标,放到坑处 ,刚从右边放过来的元素位置就有是一个新的坑,我们再从左往右找到比基点大的元素放到新坑,当然这里又是一个坑。。。
时间复杂度:O(Nlog2(N)),空间复杂度O(log2(N))
public static void quick(int [] array){int start=0,end=array.length-1;quickSort(array,start,end);}private static void quickSort(int [] array,int start,int end){if(start>=end)return;int mid=sort(array,start,end);quickSort(array,start,mid-1);quickSort(array,mid+1,end);}private static int sort(int [] array,int left,int right){int tmp=array[left];//基准int i=left;//先写右的right--,否则一遍走到left==right后与i下标交换后的那一次将会不有序while (left<right) {while (left < right && tmp <=array[right]) right--;//找到比tmp小的数array[left]=array[right];while (left < right && tmp >= array[left]) left++;//找到比tmp大的数array[right]=array[left];}array[left]=tmp;//最后入坑return left;//left==right==mid}
快排改进算法(三数取中)
思想:三数取中法,index是每次左右短点和中间点第二大的数字,防止分组不太对称,成为串,这样时间复杂度变高
public static void quick(int [] array){int start=0,end=array.length-1;quickSort(array,start,end);}private static void quickSort(int [] array,int start,int end){if(start>=end)return;//三数取中法,index是每次左右短点和中间点第二大的数字//防止分组不太对称,成为串,这样时间复杂度变高int index=indexleNum(array,start,end);//快排排序开始int mid=sort(array,start,end);quickSort(array,start,mid-1);quickSort(array,mid+1,end);}//挖坑法private static int sort(int [] array,int left,int right){int tmp=array[left];//基准int i=left;//先写右的right--,否则一遍走到left==right后与i下标交换的那一次且仅仅一次将会不有序while (left<right) {while (left < right && tmp <=array[right]) right--;//找到比tmp小的数array[left]=array[right];while (left < right && tmp >= array[left]) left++;//找到比tmp大的数array[right]=array[left];}array[left]=tmp;//最后入坑return left;//left==right==mid}private static int indexleNum(int [] array,int left,int right){int index=left+((left+right)/2);//也就三个数据,空间复杂度不高,所以可以建立一个新的数组,用冒泡int [] b=new int[3];for (int i = 0; i < b.length-1; i++) {boolean flag=false;for (int j = 0; j < array.length-1; j++) {if (array[j]>array[j+1]){swap(j,j+1,array);flag=true;}}if (flag==false)break;}return b[1];}private static void swap(int i ,int j,int [] array){int tmp=array[i];array[i]=array[j];array[j]=tmp;}
7、归并排序
时间复杂度:O(Nlog2(N)),空间复杂度O(N)
public static void mergerSort(int [] array){mergeFunc(array,0,array.length-1);}private static void mergeFunc(int [] array,int left,int right){if(left>=right){return;}int mid=left+((right-left)>>1);mergeFunc(array,left,mid);mergeFunc(array,mid+1,right);//左右拆分完毕,开始合并merge(array,mid,left,right);}private static void merge(int []array,int mid,int left,int right){int start1=left;int end1=mid;int start2=mid+1;int end2=right;int [] tmp=new int[right-left+1];int k=0;//保证两个表都有数据while (start1<=end1&&start2<=end2){if (array[start1]<=array[start2])tmp[k++]=array[start1++];else {tmp[k++]=array[start2++];}}//如果s2没有数据了但是s1中还有数据while (start1<=end1)tmp[k++]=array[start1++];//如果s1没有数据了但是s2中还有数据while (start2<=end2)tmp[k++]=array[start2++];//放回到原来数组for (int i = 0; i < k; i++) {array[i+left]=tmp[i];//i+left防止覆盖数据}}
8、总结
相关文章:

数据结构排序算详解(动态图+代码描述)
目录 1、直接插入排序(升序) 2、希尔排序(升序) 3、选择排序(升序) 方式一(一个指针) 方式二(两个指针) 4、堆排序(升序) 5、冒…...
2024-01-25 力扣高频SQL50题目1174. 即时食物配送
题目如下: 配送表: Delivery -------------------------------------- | Column Name | Type | -------------------------------------- | delivery_id | int | | customer_id | int | | order_date…...

java web 校园健康管理系统Myeclipse开发mysql数据库web结构java编程计算机网页项目
一、源码特点 java Web校园健康管理系统是一套完善的java web信息管理系统 ,对理解JSP java编程开发语言有帮助,系统具有完整的源代码和数据库,系统主要采用B/S模式开发。开发环境为 TOMCAT7.0,Myeclipse8.5开发,数据库为Mysq…...

回归预测 | Matlab基于SSA-SVR麻雀算法优化支持向量机的数据多输入单输出回归预测
回归预测 | Matlab基于SSA-SVR麻雀算法优化支持向量机的数据多输入单输出回归预测 目录 回归预测 | Matlab基于SSA-SVR麻雀算法优化支持向量机的数据多输入单输出回归预测预测效果基本描述程序设计参考资料 预测效果 基本描述 1.Matlab基于SSA-SVR麻雀算法优化支持向量机的数据…...
Java转成m3u8,hls格式
Java转成m3u8,hls格式 需求分析 大致思路 循环文件夹下面所有文件判断当前文件是否是视频文件,如果是视频文件先转为ts文件 因为听别人说先转成ts之后再切片会快很多 转成ts文件,并为这些文件单独生成一个目录,如果目录不存在则新建一个目…...

jmeter之接口测试实现参数化(利用函数助手),参数值为1-9(自增的数字)
1.前言 思考:为什么不用postman,用postman的话就得导入csv文件/json文件 如果不想导入文件,postman是实现不了,因为postman每次只会运行一次 2.jmeter函数助手实现参数化 (1)新建“线程组”--新建“http…...

如何在 Ubuntu 22.04 上安装 Apache Web 服务器
前些天发现了一个人工智能学习网站,通俗易懂,风趣幽默,最重要的屌图甚多,忍不住分享一下给大家。点击跳转到网站。 如何在 Ubuntu 22.04 上安装 Apache Web 服务器 介绍 Apache HTTP 服务器是世界上使用最广泛的 Web 服务器。它…...

【python爬虫】爬虫编程技术的解密与实战
🌈个人主页:Sarapines Programmer🔥 系列专栏: 爬虫】网络爬虫探秘⏰诗赋清音:云生高巅梦远游, 星光点缀碧海愁。 山川深邃情难晤, 剑气凌云志自修。 目录 🌼实验目的 …...

VisualSVN Server下载安装和使用方法、服务器搭建、使用TortoiseSvn将项目上传到云端服务器、各种错误解决方法
VisualSVN Server下载安装和使用方法、服务器搭建、使用TortoiseSvn将项目上传到云端服务器、各种错误解决方法 0.写在前面00.电脑配置01.思路 1.VisualSVN Server下载安装01.下载02.安装03.电脑命名不能有中文04.制作VisualSVN Server快捷方式05.License limits exceeded, Som…...

Python模块与包:扩展功能、提高效率的利器
文章目录 一、引言1.1 模块与包对于Python开发的重要性1.2 Python作为拥有丰富生态系统的编程语言 二、为什么学习模块与包2.1 复用代码:利用现有模块与包加速开发过程2.2 扩展功能:通过模块与包提供的功能增强应用的能力 三、模块的使用3.1 导入模块&am…...

【每日一题】4.LeetCode——杨辉三角
📚博客主页:爱敲代码的小杨. ✨专栏:《Java SE语法》 ❤️感谢大家点赞👍🏻收藏⭐评论✍🏻,您的三连就是我持续更新的动力❤️ 🙏小杨水平有限,欢迎各位大佬指点&…...

蓝桥杯(Python)每日练Day5
题目 OJ1229 题目分析 题目完全符合栈的特征,后进先出。如果能够熟练使用列表的9种方法那么这道题很容易解出。 题解 a[]#存衣服 nint(input()) for i in range(n):llist(input().split())#判断每一步的操作if len(l[0])2:a.append(l[1])else:while a.pop()!l…...

SpringCloud(二)
Spring Cloud 文章目录 Spring Cloud任务三:Spring Cloud与微服务架构1.Spring Cloud课程内容介绍2.单体应用架构2.1 互联网应用架构演进2.2 单体应用架构 3.垂直应用架构4.SOA应用架构5.微服务应用架构介绍6.微服务架构核心思想及优缺点7.微服务架构的核心概念8.Sp…...

【java】常见的面试问题
目录 一、异常 1、 throw 和 throws 的区别? 2、 final、finally、finalize 有什么区别? 3、try-catch-finally 中哪个部分可以省略? 4、try-catch-finally 中,如果 catch 中 return 了,finally 还会执行吗&#…...

虚幻UE 插件-像素流送实现和优化
本笔记记录了像素流送插件的实现和优化过程。 UE version:5.3 文章目录 一、像素流送二、实现步骤1、开启像素流送插件2、设置参数3、打包程序4、打包后的程序进行像素流参数设置5、下载NodeJS6、下载信令服务器7、对信令服务器进行设置8、启动像素流送 三、优化1、…...

Vue2 props组件通信
一、父组件向子组件传值 1、流程图 2、父组件代码 <template><div class"app"><UserInfo:usernameusername:ageage:isSingleisSingle:carcar:hobbyhobby></UserInfo></div> </template><script> import UserInfo from .…...

重构改善既有代码的设计-学习(三):重新组织数据
1、拆分变量(Split Variable) 有些变量用于保存一段冗长代码的运算结果,以便稍后使用。这种变量应该只被赋值一次。 如果它们被赋值超过一次,就意味它们在函数中承担了一个以上的责任。如果变量承担多个责任,它就应该被…...
群狼调研(长沙品牌忠诚度测试)|广告效果测评方法
广告效果测评方法可以根据具体的目标和需求而有所差异,以下是一些常见的广告效果测评方法: 1.品牌调研和调查:通过定量或定性的调研和调查方法,评估广告对品牌认知、品牌形象和品牌偏好的影响,包括品牌知名度、品牌关联…...

Gradle学习笔记:Gradle的使用方法
文章目录 1.初始化项目2.构建脚本语言选择3.项目命名4.项目构建过程 1.初始化项目 创建一个test空文件夹,在该文件夹下打开终端,并执行命令:gradle init. 会有一个选项让你选择项目的类型。下面是每个选项的含义和用途: basic&am…...

少儿编程 2023年12月电子学会图形化编程等级考试Scratch二级真题解析(选择题)
2023年12月scratch编程等级考试二级真题 选择题(共25题,每题2分,共50分) 1、在制作推箱子游戏时,地图是用数字形式储存在电脑里的,下图是一个推箱子地图,地图表示如下:第一行( 111111)第二行( 132231) 第三行( 126621) 第四行( ) 第五行( 152321) 第六行( 111111 ) 根…...

CMake基础:构建流程详解
目录 1.CMake构建过程的基本流程 2.CMake构建的具体步骤 2.1.创建构建目录 2.2.使用 CMake 生成构建文件 2.3.编译和构建 2.4.清理构建文件 2.5.重新配置和构建 3.跨平台构建示例 4.工具链与交叉编译 5.CMake构建后的项目结构解析 5.1.CMake构建后的目录结构 5.2.构…...

STM32标准库-DMA直接存储器存取
文章目录 一、DMA1.1简介1.2存储器映像1.3DMA框图1.4DMA基本结构1.5DMA请求1.6数据宽度与对齐1.7数据转运DMA1.8ADC扫描模式DMA 二、数据转运DMA2.1接线图2.2代码2.3相关API 一、DMA 1.1简介 DMA(Direct Memory Access)直接存储器存取 DMA可以提供外设…...
如何为服务器生成TLS证书
TLS(Transport Layer Security)证书是确保网络通信安全的重要手段,它通过加密技术保护传输的数据不被窃听和篡改。在服务器上配置TLS证书,可以使用户通过HTTPS协议安全地访问您的网站。本文将详细介绍如何在服务器上生成一个TLS证…...
Java 加密常用的各种算法及其选择
在数字化时代,数据安全至关重要,Java 作为广泛应用的编程语言,提供了丰富的加密算法来保障数据的保密性、完整性和真实性。了解这些常用加密算法及其适用场景,有助于开发者在不同的业务需求中做出正确的选择。 一、对称加密算法…...

2025盘古石杯决赛【手机取证】
前言 第三届盘古石杯国际电子数据取证大赛决赛 最后一题没有解出来,实在找不到,希望有大佬教一下我。 还有就会议时间,我感觉不是图片时间,因为在电脑看到是其他时间用老会议系统开的会。 手机取证 1、分析鸿蒙手机检材&#x…...
AI编程--插件对比分析:CodeRider、GitHub Copilot及其他
AI编程插件对比分析:CodeRider、GitHub Copilot及其他 随着人工智能技术的快速发展,AI编程插件已成为提升开发者生产力的重要工具。CodeRider和GitHub Copilot作为市场上的领先者,分别以其独特的特性和生态系统吸引了大量开发者。本文将从功…...

华为云Flexus+DeepSeek征文|DeepSeek-V3/R1 商用服务开通全流程与本地部署搭建
华为云FlexusDeepSeek征文|DeepSeek-V3/R1 商用服务开通全流程与本地部署搭建 前言 如今大模型其性能出色,华为云 ModelArts Studio_MaaS大模型即服务平台华为云内置了大模型,能助力我们轻松驾驭 DeepSeek-V3/R1,本文中将分享如何…...
在web-view 加载的本地及远程HTML中调用uniapp的API及网页和vue页面是如何通讯的?
uni-app 中 Web-view 与 Vue 页面的通讯机制详解 一、Web-view 简介 Web-view 是 uni-app 提供的一个重要组件,用于在原生应用中加载 HTML 页面: 支持加载本地 HTML 文件支持加载远程 HTML 页面实现 Web 与原生的双向通讯可用于嵌入第三方网页或 H5 应…...

莫兰迪高级灰总结计划简约商务通用PPT模版
莫兰迪高级灰总结计划简约商务通用PPT模版,莫兰迪调色板清新简约工作汇报PPT模版,莫兰迪时尚风极简设计PPT模版,大学生毕业论文答辩PPT模版,莫兰迪配色总结计划简约商务通用PPT模版,莫兰迪商务汇报PPT模版,…...

手机平板能效生态设计指令EU 2023/1670标准解读
手机平板能效生态设计指令EU 2023/1670标准解读 以下是针对欧盟《手机和平板电脑生态设计法规》(EU) 2023/1670 的核心解读,综合法规核心要求、最新修正及企业合规要点: 一、法规背景与目标 生效与强制时间 发布于2023年8月31日(OJ公报&…...