【算法篇】八种内排序算法

常用的八种内排序算法分别是:

  1. 交换排序:冒泡排序、快速排序
  2. 选择排序:简单选择排序、堆排序
  3. 插入排序:直接插入排序、希尔排序
  4. 归并排序
  5. 基数排序

内排序巧记:选(选择)舰(简单选择)队(堆)的时候脚(交换)毛(冒泡)快(快速),需要把轨(归并)迹(基数)擦(插入)仔(直接插入)细(希尔)

一、算法的概念和编码实现(Java)

1、冒泡排序

冒泡排序的基本思想是,对相邻的元素进行两两比较,顺序相反则进行交换,这样,每一趟会将最小或最大的元素“浮”到顶端,最终达到完全有序

代码实现(升序)

	public static void selectSort(int[] array) {int len = array.length;boolean flag = true;for (int i = 0; i < len - 1 && flag; i++) {flag = false;for (int j = 0; j < len - i - 1; j++) {if (array[j] > array[j + 1]) {int temp = array[j];array[j] = array[j + 1];array[j + 1] = temp;flag = true;}}}}

 

最好情况的时间复杂度最坏情况的时间复杂度特点稳定性
T(n)=O(n)T(n)=O(n2)如果数据已经排序好,一次都不交换或者交换次数很少,效率很高;如果是完全逆序,则要不停的两两交换,效率很低稳定

2、简单选择排序

简单选择排序的基本思想是,每一趟从待排序的数据元素中选择一个最小(或者最大)的元素作为首元素,直到所有元素排完为止。

代码实现(升序):

	public static void selectSort(int[] array) {int len = array.length;for (int i = 0; i < len-1; i++) {int min = i;// 每趟排序默认第一个元素是最小的元素,记住下标for (int j = i + 1; j < len; j++) {// 从i+1的位置开始,依次同最小元素比较,若比最小元素小,则记住当前下标if (array[j] < array[min]) {min = j;}}// 无序区最小元素同无序区的第一个元素交换if (min != i) {int temp = array[min];array[min] = array[i];array[i] = temp;}}}
时间复杂度特点稳定性
T(n)=O(n2)简单,相对于冒泡排序来说交换次数少不稳定

3、直接插入排序

直接插入排序基本思想是不断将无序区的元素插入到有序区的适当位置,直到无序区没有元素排完为止

代码实现(升序):

	private static void insertSort(int[] array) {for (int i = 1; i < array.length; i++) {int j ;int temp = array[i];for (j = i; j>0 && temp < array[j-1]; j--) {array[j] = array[j-1];}array[j] = temp;}}

 

最好情况的时间复杂度最坏情况的时间复杂度特点稳定性
T(n)=O(n)T(n)=O(n2)简单稳定

4、快速排序

对冒泡排序的一种改进,它的思想是:将元素分为两组,一组的元素比另外一组的所有元素都要小,然后再按照此方法对两组元素进行排序。

快速排序我这里就不写了,快速排序相对于前面三种排序方式来说要复杂很多,看了一些博客,发现写得都不怎么样,这里推荐一个讲快速排序的视频https://www.bilibili.com/video/av39519566/?redirectFrom=h5

附上代码实现(参考视频中的):

public static void quickSort(int[] arr,int left,int right){//如果左边索引比右边索引更大或者相等,直接使用return结束这个方法if(left >= right){return;}//定义变量保存基准数int base = arr[left];//定义变量i,指向最左边int i = left;//定义变量j,指向最右边int j = right;//当i和j不相遇的时候,在循环中进行检索while(i!=j){//先由j从右向左检索比基准数小的就停下,否则继续检索while(arr[j]>=base && i<j){j--;}//在由i从左向右检索比基准数大的就停下,否则继续检索while(arr[i]<=base && i<j){i++;}//代码走到这里,i停下了,j也停下了,然后交换i和j位置的元素int temp = arr[i];arr[i] = arr[j];arr[j] = temp;}//交换基准数和相遇位置的元素arr[left] = arr[i];arr[i] = base;//排基准数左边的quickSort(arr,left,i-1);//排基准数右边的quickSort(arr,j+1,right);}
最好情况的时间复杂度最坏情况的时间复杂度平均时间复杂度特点稳定性
T(n)=O(nlogn)T(n)=O(n2)T(n)=O(nlogn)较复杂不稳定

5、希尔排序

希尔排序是对直接插入排序的优化,原理是:将数据按照步长dk分为dk个子列,然后再对每个子列运用直接插入排序。

当步长为5的时候,分组情况如下:

 

每个子列排好序后,变成:

代码实现(升序):

	public static void main(String[] args) {int[] array = {49,38,65,97,76,13,27,49,55,4};print(array);ShellSort(array,5);print(array);ShellSort(array,3);print(array);ShellSort(array,1);print(array);}private static void print(int[] array){for (int i = 0; i < array.length; i++) {System.out.print(array[i]+"\t");}System.out.println("\n");}//希尔排序,dk表示步长private static void ShellSort(int[] array,int dk) {for(int k = 0;k<dk;k++){//每个子组做直接插入插入排序for(int i = dk+k;i<array.length;){int j ;int temp = array[i];for (j = i; j-dk>=0 && temp < array[j-dk]; ) {j -= dk;//上一个元素的索引需要减去dk,而不是减1array[j] = array[j-dk];}array[j] = temp;i += dk;//下一个元素索引加上dk,而不是加1}}}

说明:从代码层面来看,希尔排序相对于直接插入排序的不同点在于希尔排序外层多了一层循环,用来将原序列分层若干个子列。内部的直接插入排序做减减或者加加时要改成减去步长或者加上步长

二、时间复杂度和空间复杂度分析

排序的稳定性:根据关键字相同(如果数值比较的话是指大小)的记录排序前后相对位置的变化,可以分为稳定性排序算法和不稳定性排序算法。在排序的序列中,如果存在两个记录Ri和Rj,其关键字分别为Ki和Kj,并且i<=j,Ki=Kj,即记录Ri在Rj之前,排序完成后,如果记录Ri和Rj的相对位置不发生改变,那么该算法是稳定性排序,否则是不稳定排序。

排序方法时间复杂度(最坏情况)空间复杂度(辅助空间)稳定性复杂性
简单选择排序O(n2)O(1)不稳定简单
冒泡排序O(n2)O(1)稳定简单
快速排序O(n2) 不稳定较复杂
直接插入排序O(n2)O(1)稳定简单
希尔排序O(n2)O(1)不稳定较复杂

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

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

相关文章

数据分析专题报告范文6篇_小学生看图写话范文:小熊玩跷跷板?(6篇),让孩子参考练习...

​范文01&#xff1a;小熊跷跷板一天&#xff0c;天气晴朗&#xff0c;胖乎乎的小熊和小白兔一起玩跷跷板。小熊一屁股坐在地上&#xff0c;小白兔说&#xff1a;“啊&#xff01;我有恐高症哇&#xff01;”小熊说&#xff1a;“我比你重&#xff0c;所以你没有办法把我翘起来…

PL/SQL

1 PL/SQLPL/SQL:过程化SQL语言&#xff08;Procedural Language/SQL&#xff09;。PL/SQL是Oracle数据库对SQL语句的扩展。在普通SQL语句的使用上增加了编程语言的特点&#xff0c;所以PL/SQL把数据操作和查询语句组织在PL/SQL代码的过程性单元中&#xff0c;通过逻辑判断、循环…

20sccm_SCCM 2012安装图解教程(一步一步详细步骤)

本系列文章的环境架构如下图所示&#xff1a;所有服务器安装的操作系统都是windows Server 2008 R2 中文企业版。计算机名软件、版本及角色SC-DC.SC.COMwindows Server 2008 R2 Enterprise /Active Directory 2008 R2SC-SQL.SC.COMSQL Server 2008 R2 EnterpriseSC-SCCM.SC.COM…

【Java中级篇】Dom4j解析xml数据

一、依赖 <dependency><groupId>dom4j</groupId><artifactId>dom4j</artifactId><version>1.6.1</version></dependency> 二、test.xml <?xml version"1.0" encoding"UTF-8"?> <students>…

redis 附近的人_使用redis—geo api实现搜索附近的人,自己写的一个composer包

安装如果是应用在项目当中的话找到根目录&#xff0c;需要和 composer.json同级composer require gaopengfei/redis_lbs基本操作初始化require_once __DIR__./vendor/autoload.php;$lbs new \LBS\Services\LBSService();添加$add_params [[name > yabao_road,long > 11…

【Java中级篇】使用zxing生成二维码

一、pom.xml添加依赖 <dependency><groupId>com.google.zxing</groupId><artifactId>core</artifactId><version>3.1.0</version></dependency><dependency><groupId>com.google.zxing</groupId><artifa…

微信小程序弹出框竖向滚动_微信小程序 解决自定义弹出层滑动时下层页面滚动问题...

WXML将整个底层页面使用 scroll-view 包裹起来&#xff0c;设置 scroll-y 当显示弹出层的时候为 true&#xff0c; 闭关弹出层的时候为 falseWXSSPage 设置为绝对定位&#xff0c;宽高各百分之百 &#xff0c; scroll-view 高度 百分之百Page{position: absolute;width: 100%;h…

win10环境安装使用svn客户端和服务端

一、下载安装包 安装包下载传送门http://subversion.apache.org/packages.html 无法下载的童鞋去百度云下载 链接&#xff1a;https://pan.baidu.com/s/1EuGohoZKIPmRvynp5-Subw 提取码&#xff1a;ohna 链接&#xff1a;https://pan.baidu.com/s/1EJrd5DzGCBE4rRfdhuno6Q …

openglshader实现虚拟场景_opengl – 如何使用GLSL着色器将径向模糊应用于整个场景?...

我在GLSL中有一个径向模糊着色器,它采用纹理,对其进行径向模糊,并将结果呈现给屏幕.这个工作很好,到目前为止.问题在于,它将径向模糊应用于场景中的第一个纹理.但是我实际上想做的就是将这个模糊应用于整个场景.实现此功能的最佳方式是什么&#xff1f;我可以只使用着色器,还是…

记一次尴尬的面试

昨天信达雅公司邀请我去平安面试&#xff0c;然后我今天10点到科技信息中心&#xff0c;等了接近20分钟才有人过来接我。 第一个环节是机试 40个题目&#xff0c;主要是选择题&#xff0c;花了40分钟结束战斗&#xff0c;总分100得了75分&#xff08;手机快没电了&#xff0c…

所选元素非联通_非固化橡胶沥青防水涂料与耐根穿刺防水卷材(沥青基)施工要点...

目前&#xff0c;非固化复合耐根穿刺防水卷材在车库顶板的应用逐渐受到客户及用户的认可&#xff0c;也有不少慕名而来的防水从业者打电话来咨询此系统的应用情况及优势。下面就由小编来给大家系统介绍此应用系统的特点吧。01性能优势1.两种材料高度的相容性非固化橡胶沥青防水…

事务的理解

事务的概念 事务是一组SQL组成的逻辑处理单元&#xff0c;通常有四个特性&#xff0c;简称ACID&#xff1a; 原子性&#xff08;Atomic&#xff09;&#xff1a;数据库事务是不可分割的工作单位。事务中的SQL语句要么都执行成功&#xff0c;要么都执行失败。 一致性&#xf…

vscode设置templates_在VScode中创建你的代码模板的方法

使用VScode的用户代码片段功能&#xff0c;来生成自己习惯的代码模板&#xff0c;提升开发效率1.选择菜单里的 文件 > 首选项 > 用户代码片段2.选择你需要自定义模板的文件&#xff0c;以vue为例3. 配置对应文件json把代码片段写在json里。每个代码段都是在一个代码片段名…

【Java中级篇】动态代理机制

要想搞明白动态代理之前&#xff0c;我们先来了解一下代理是什么意思&#xff0c;先来谈谈设计模式中的代理模式。 什么是代理模式&#xff08;Proxy&#xff09; 定义&#xff1a;给目标对象提供一个代理对象&#xff0c;并由代理对象控制对目标对象的引用。 在代理模式中&…

二维分类教案_幼儿园中班数学教案中班数学教案二维排序——师乐汇幼儿教师教育网...

中班数学教案&#xff1a;二维排序一、活动目标&#xff1a;1. 在分类的基础上初步运用二维排列表进行物品放置。2. 通过场景设置、温故知新由易到难的课程安排&#xff0c;幼儿能积极参与大胆表达并且根据表格来进行物品放置。3&#xff0e;在生活化的情境中体验学习数学活动的…

【JAVA基础篇】String类详解

昨天参加了一场机试&#xff0c;发现自己居然对String类的api不熟了&#xff0c;所以今天来总结一下&#xff08;基于JDK1.8&#xff09;。 1、父类和实现的接口 没有父类&#xff0c;或者说父类是Object 接口&#xff1a;Serializable、Comparable<String>、CharSequ…

python精确计时_PYTHON在WINDOWS下高精度计时的体会

2011-02-23 14:51:19其实也是WINDOWS下的通用办法啦&#xff0c;只不过我用PYTHON表达。用win32api.GetSystemTime()不是太精确&#xff0c;值15毫秒才变一下&#xff0c;最好用time.clock()&#xff0c;这个能到毫秒级&#xff0c;最精确的办法是用QueryPerformanceFrequency(…

什么叫大数据人物画像_大数据时代,如何构建精准用户画像,直击精细化运营...

移动互联网时代&#xff0c;精细化运营逐渐成为企业发展的重要竞争力&#xff0c;“用户画像”的概念也应运而生。用户画像是指&#xff0c;在大数据时代&#xff0c;企业通过对海量数据信息进行清洗、聚类、分析&#xff0c;将数据抽象成标签&#xff0c;再利用这些标签将用户…

【Java中级篇】使用itextpdf生成PDF

我们可以发现很多求职网站都会将我们录入的信息来生成一个PDF简历文件。所以我这里提供了用itextpdf生成的PDF的代码。 一、步骤 1.1、使用Adobe Acrobat Pro工具编辑PDF模板 1.2、根据PDF模板文件路径创建一个PDFReader对象 1.3、创建一个输出流对象&#xff0c;用于存放生…

adb bugreport保存位置_adb 常用命令---日常提升效率

做为 Android 开发&#xff0c;怎么能不懂点 adb 命令呢&#xff1f;速看~adb 重置、断连的状况这里不说了&#xff0c;先来说一些直观的命令吧1、adb devices查看当前连接的设备如果当前正在连接着设备&#xff0c;那么就可以进行后续的操作了&#xff0c;如果没有&#xff0c…