【数据结构】排序算法总结

news/2025/2/21 8:01:18/

⭐ 作者:小胡_不糊涂
🌱 作者主页:小胡_不糊涂的个人主页
📀 收录专栏:浅谈数据结构
💖 持续更文,关注博主少走弯路,谢谢大家支持 💖

总结

  • 1. 归并排序
  • 2. 计数排序
  • 3. 排序算法复杂度及稳定性分析

在这里插入图片描述
在总结之前我们先介绍一下归并排序和计数排序!

1. 归并排序

归并排序(MERGE-SORT) 是建立在归并操作上的一种有效的排序算法,该算法是采用分治法(Divide andConquer)的一个非常典型的应用。
将已有序的子序列合并,得到完全有序的序列;即先使每个子序列有序,再使子序列段间有序。若将两个有序表合并成一个有序表,称为二路归并。 归并排序核心步骤:
在这里插入图片描述

代码实现:

/*** 归并排序* 时间复杂度:O(N*logN)* 空间复杂度:O(logN)* 稳定性:稳定的排序* 目前为止3个稳定的排序:直接插入排序、冒泡排序、归并排序* @param array*/public static void mergeSort(int[] array){mergeSortFun(array,0,array.length-1);}private static void mergeSortFun(int[] array,int start,int end){if(start>=end){return;}//拆分int mid=(start+end)/2;mergeSortFun(array,start,mid);mergeSortFun(array,mid+1,end);merge(array,start,mid,end);//合并}private static void merge(int[] array,int left,int mid,int right){//定义拆分后的左边部分int s1=left;int e1=mid;//定义拆分后的右边部分int s2=mid+1;int e2=right;//定义一个新数组存放合并后的数据int[] tmp=new int[right-left+1];int i=0;//tmp的下标//同时满足-证明两个归并段都有数据while(s1<=e1&& s2<=e2){if(array[s1]<=array[s2]){tmp[i++]=array[s1++];}else{tmp[i++]=array[s2++];}}while(s1<=e1){tmp[i++]=array[s1++];}while (s2 <= e2) {tmp[i++]=array[s2++];}//把排好序的数据 拷贝回原来的数组array当中for(int j=0;j<tmp.length;j++){array[j+left]=tmp[j];}}

归并排序可以解决海量数据的排序问题:
外部排序:排序过程需要在磁盘等外部存储进行的排序
前提: 内存只有 1G,需要排序的数据有 100G
因为内存中因为无法把所有数据全部放下,所以需要外部排序,而归并排序是最常用的外部排序。

  1. 先把文件切分成 200 份,每个 512 M
  2. 分别对 512 M 排序,因为内存已经可以放的下,所以任意排序方式都可以
  3. 进行 2 路归并,同时对 200 份有序文件做归并过程,最终结果就有序了

2. 计数排序

基本思想: 计数排序又称为鸽巢原理,是对哈希直接定址法的变形应用。 操作步骤:

  1. 统计相同元素出现次数
  2. 根据统计的结果将序列回收到原来的序列中

代码实现:

/*** 计数排序的场景:* 指定范围内的数据* 时间复杂度: O(MAX(N,范围))* 空间复杂度:O(范围)* 稳定性:稳定的排序* @param array*/public static void countSort(int[] array) {//寻找最大值、最小值int maxvalue=array[0];int minvalue=array[0];for(int i=0;i<array.length;i++){if(array[i]>maxvalue){maxvalue=array[i];}if(array[i]<minvalue){minvalue=array[i];}}int[] countarr=new int[maxvalue-minvalue+1];//记录array中元素出现个数,初始值都为0for(int i=0;i<array.length;i++){countarr[array[i]-minvalue]++;}int index=0;//重新定义array下标for(int i=0;i<countarr.length;i++){while(countarr[i]>0){array[index]=i+minvalue;index++;countarr[i]--;}}}

3. 排序算法复杂度及稳定性分析

在这里插入图片描述

排序方法最好平均最坏空间复杂度稳定性
冒泡排序O(n)O(n^2)O(n^2)O(1)稳定
插入排序O(n)O(n^2)O(n^2)O(1)稳定
选择排序O(n^2)O(n^2)O(n^2)O(1)不稳定
希尔排序O(n)O(n^1.3)O(n^2)O(1)不稳定
堆排序O(n * log(n))O(n * log(n))O(n * log(n))O(1)不稳定
快速排序O(n * log(n))O(n * log(n))O(n^2)O(log(n)) ~ O(n)不稳定
归并排序O(n * log(n))O(n * log(n))O(n * log(n))O(n)稳定

http://www.ppmy.cn/news/1189567.html

相关文章

选择适合制造业的企业邮箱平台

自2010年成立以来&#xff0c;J公司已从一家小型有限责任公司发展成为全球领先的工业内窥镜研发、生产和销售企业。公司的产品制造采用国际先进技术和一流生产工艺&#xff0c;专业为客户提供定制解决方案&#xff0c;产品已广泛应用于锅检特检、机械制造、发电、石油、燃气、化…

android中gradle的kotlin编译配置选项

一、编译配置 1、Android中的配置 使用如下方式开启在Android中的gradle的kotlin编译配置&#xff1a; 该配置在其余平台不可用 android {...compileOptions {sourceCompatibility JavaVersion.VERSION_17targetCompatibility JavaVersion.VERSION_17}kotlinOptions {jvmTar…

【计算机网络笔记】传输层——可靠数据传输原理之Rdt协议

系列文章目录 什么是计算机网络&#xff1f; 什么是网络协议&#xff1f; 计算机网络的结构 数据交换之电路交换 数据交换之报文交换和分组交换 分组交换 vs 电路交换 计算机网络性能&#xff08;1&#xff09;——速率、带宽、延迟 计算机网络性能&#xff08;2&#xff09;…

数学分析:傅里叶变换(完结撒花)

这里我觉得老师讲的更好。首先我们已经知道了周期函数的傅里叶级数&#xff0c;接下来对于非周期函数&#xff0c;其实可以看成周期无穷大的函数。我们把周期经过一个换元&#xff0c;重新看这个傅里叶级数。 这里要注意&#xff0c;我们发现这个无限周期的傅里叶级数&#xff…

基于PyTorch的共享单车使用数量预测研究

收藏和点赞&#xff0c;您的关注是我创作的动力 文章目录 概要 一、预测模型的实现3.1数据的获取和预处理3.2划分数据集3.3构建神经网络 二、PyTorch框架三 原理2.1前馈神经网络2.1.1 BP神经网络 四 预测效果验证4.1小批量梯度下降4.2批量梯度下降4.3随机梯度下降 五 结 论目录…

达梦数据库快速配置主备

主备机服务器初始化数据库实例并启动数据库 主机操作&#xff1a; 创建数据库实例&#xff1a; cd /opt/dmdbms/bin/bin ./dminit path/opt/dmdbms/data page_size32 extent_size32 log_size2048 case_sensitiven charset1 length_in_char1 db_nameDAMENG instance_nameDMSERV…

数据库的锁

锁 在数据库管理中&#xff0c;锁是一种关键的工具&#xff0c;用于协调并发访问数据库的共享资源。MySQL作为一种常见的关系型数据库管理系统&#xff0c;也采用了多种锁机制来确保数据的完整性和一致性。 什么是锁 数据库的锁是为了支持对共享数据的并发访问&#xff0c;提…

数据湖Iceberg介绍和使用(集成Hive、SparkSQL、FlinkSQL)

文章目录 简介概述作用特性数据存储、计算引擎插件化实时流批一体数据表演化&#xff08;Table Evolution&#xff09;模式演化&#xff08;Schema Evolution&#xff09;分区演化&#xff08;Partition Evolution&#xff09;列顺序演化&#xff08;Sort Order Evolution&…