排序算法之希尔排序(缩小增量排序)

news/2024/12/23 8:33:13/

 希尔排序是插入排序的优化,如果不了解插入排序可以看算法>排序算法之插入排序-CSDN博客这篇博客,希尔算法>排序算法通过对原始数据集使用 gap 分组的方法先将数据分组进行插入排序,随着排序的进行,逐渐减小 gap 的值,直至 gap 为1,此时进行最后一次类似插入排序的过程,但因为之前的预排序,数组已经接近有序,所以最后一次操作效率很高。这种方法相较于简单的插入排序大大减少了数据移动的次数,特别是在处理大规模乱序数组时,效率提升显著。因此,可以说希尔排序是对传统插入算法>排序算法的一种有效改进或优化。

那么我们来看一下希尔排序是如何排序的吧!


 


 

 


 

那么代码是如何实现的呢?请看下面 

java">public static int[] shellsort(int[] array){int gap = array.length;while(gap>1){gap/=2;shell(array,gap);}return array;
}private static void shell(int[] arr,int gap){for (int i = gap; i < arr.length; i++) {int tmp = arr[i];int j = i-gap;for(;j>=0;j-=gap){if(arr[j] > tmp){arr[j+gap] = arr[j];} else {break;}}arr[j+gap] = tmp;}
}

对于希尔排序,由于对gap的不同取值会影响最终的时间复杂度

 

时间复杂度:大致O(n^1.25)到O(1.6*n^1.25)

空间复杂度:O(1)

稳定性:不稳定,因为在不同的步长下,相等的元素可能会因为插入排序的过程中被重新安排位置,从而改变它们之间的原始相对顺序。因此,如果数据序列中存在相等的元素,并且对这些元素的原始顺序有保持要求,那么希尔排序可能不是最合适的选择。


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

相关文章

ThreeJS:纹理的颜色空间

色彩空间Color Space 在ThreeJS中&#xff0c;纹理的colorSpace属性用于定义文里的颜色空间。 颜色空间是一个用于描述颜色的数学模型&#xff0c;在现实生活中&#xff0c;人眼可以观察到无数种颜色&#xff0c;而颜色空间就是用来描述这些颜色的一个方法&#xff0c;不同的颜…

Node.js -- MongoDB

文章目录 1. 相关介绍2. 核心概念3. 命令行交互3.1数据库命令3.2 集合命令3.3 文档命令 4. 数据库应用场景4.1 新增4.2 删除4.3 更新4.4 查询 5. 图形化工具Robo 3T 1. 相关介绍 一、简介 Mongodb是什么 MongoDB是一个基于分布式文件存储的数据库&#xff0c;官方地址https://…

three.js入门指南

WebGL和Three.js的概念 什么是WebGL WebGL是基于OpenGL ES 2.0的Web标准&#xff0c;可以通过HTML5 Canvas元素作为DOM接口访问。 也就是WebGL是作为OpenGL的网页端入口。它作为一个底层标准&#xff0c;然后我们可以通过JavaScript代码&#xff0c;在网页上实现三维图形的渲…

关于win平台c语言引入开源库的问题与解决

许久不写博客&#xff0c;五一还在加班&#xff0c;就浅浅写一篇吧 最近除了做物联网平台 还对网关二次开发程序做了修改&#xff0c;网关的二次开发去年年底的时候做过&#xff0c;但是当时的逻辑不是十分完善&#xff0c;差不多已经过了半年了&#xff0c;很多细节已经忘记了…

RabbitMQ之生产批量发送

为什么要用生产批量发送&#xff1f; 批量发送消息&#xff0c;可以提高MQ发送性能。但是 RabbitMQ 并没有提供了批量发送消息的 API 接口,使用 spring-amqp 的 BatchingRabbitTemplate 实现批量能力。 SimpleBatchingStrategy 发送策略满足以下规则会进行发送&#xff1a; ba…

【工具使用】如何查看电脑的显存大小

操作步骤&#xff1a; winR&#xff0c;输入“dxdiag”&#xff1a; 点击显示&#xff1a; 可以看到&#xff0c;显存为8G左右。

5分钟速通大语言模型(LLM)的发展与基础知识

✍️ 作者&#xff1a;哈哥撩编程&#xff08;视频号同名&#xff09; 博客专家全国博客之星第四名超级个体COC上海社区主理人特约讲师谷歌亚马逊演讲嘉宾科技博主极星会首批签约作者 &#x1f3c6; 推荐专栏&#xff1a; &#x1f3c5; 程序员&#xff1a;职场关键角色通识宝…

初识Vue-组件通信(详解props和emit)

目录 一、组件通信介绍 1.概念 2.作用 3.特点 4.应用 二、组件通信语法 1.Props 1.1.在子组件中声明 props 1.2.在父组件中传递数据 2.Emit 2.1.在子组件中触发事件 2.2.在父组件中监听事件 三、应用实例 1. 购物车组件 2. 表单数据处理 四、总结 一、组件通信介…