标签:arr temp int gap 希尔 增量 排序 移位
希尔排序是直接插入排序算法的一种更高效的改进版本,又称"缩小增量排序"。希尔排序是把记录按下标的一定增量分组,对每组使用直接插入排序算法排序;随着增量逐渐减少,每组包含的关键词越来越多,当增量减至1时,算法结束。
希尔排序:
时间复杂度是O(nlogn)
最好情况O(nlog2n)
最坏情况O(nlog2n)
空间复杂度 O(1)
排序方式不占用额外内存,希尔排序是不稳定的。
图解
核心代码
public static void shellSort(int arr[]){
//增量gap,并逐步的缩小增量
for (int gap = arr.length/2; gap > 0; gap /= 2) {
//从第gap个元素,逐个对其所在的组进行直接插入排序
for (int i = gap; i < arr.length; i++) {
int j = i;
int temp = arr[j];
if (arr[j] < arr[j - gap]){
while (j - gap >= 0 && temp < arr[j-gap]){
//移动
arr[j] = arr[j - gap];
j -= gap;
}
//当退出while后,就给temp找到插入的位置
arr[j] = temp;
}
}
}
}
标签:arr,temp,int,gap,希尔,增量,排序,移位 来源: https://blog.csdn.net/amazinga/article/details/106978006
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。