網(wǎng)站首頁 編程語言 正文
插入排序分為兩種:直接插入排序&希爾排序
希爾排序
1.基本思想
希爾排序是在直接插入排序基礎(chǔ)上的優(yōu)化,屬于非常牛掰的一個排序。
核心思想:
- 先進(jìn)行預(yù)排序,讓數(shù)組接近有序;
- 直接插入排序
預(yù)排序
預(yù)排序步驟:
分組排,假設(shè)gap==3,間隔為gap的為一組,然后分別使用插入排序的思想對這gap組數(shù)據(jù)進(jìn)行排序
多組間隔為gap的預(yù)排序,gap由大變小,gap越大,大的數(shù)可以越快的到后面,小的數(shù)可以越快得到前面,gap越大,預(yù)排完越不接近有序,gap越小,預(yù)排完越接近有序,gap為1時就是直接插入排序
動圖演示:
預(yù)排序代碼:
for (int i = 0; i < gap; i++)//有g(shù)ap組需要排
{
for (int j = i; j < n - gap; j += gap)//內(nèi)層循環(huán),先排紅,再排綠,最后排藍(lán)
//注意內(nèi)層循環(huán)的寫法
{
//跟直接插入排序很像,不同的是需要使用gap
int end = j;
int tmp = a[end + gap];
while (end >= 0)
{
if (a[end] > tmp)
{
a[end + gap] = a[end];
end -= gap;
}
else
{
break;
}
}
a[end + gap] = tmp;
}
}
這是最初的寫法,其實這個代碼是可以優(yōu)化的:
//預(yù)排序優(yōu)化
for (int i = 0; i < n - gap; i++)
//把間隔為gap的多組數(shù)據(jù)同時排
//當(dāng)?shù)絥-gap-1的位置就終止了
{
int end = i;
int tmp = a[end + gap];
while (end >= 0)
{
if (a[end] > tmp)
{
a[end + gap] = a[end];
end -= gap;
}
else
{
break;
}
}
a[end + gap] = tmp;
}
2.算法實現(xiàn)
//希爾排序
void ShellSort(int* a, int n)
{
//一開始初始化gap為n
int gap = n;
while (gap > 1)//gap大于1都是預(yù)排序,gap==1時為直接插入排序
{
//為保證gap最終結(jié)果為1,可以gap/=2,也可以是gap=gap/3+1;
gap /= 2;
//預(yù)排序優(yōu)化
for (int i = 0; i < n - gap; i++)
//把間隔為gap的多組數(shù)據(jù)同時排
//當(dāng)?shù)絥-gap-1的位置就終止了
{
int end = i;
int tmp = a[end + gap];
while (end >= 0)
{
if (a[end] > tmp)
{
a[end + gap] = a[end];
end -= gap;
}
else
{
break;
}
}
a[end + gap] = tmp;
}
}
}
完整代碼:
3.時間復(fù)雜度
希爾排序的時間復(fù)雜度是:O(N*logN)
原文鏈接:https://bit-runout.blog.csdn.net/article/details/124702416
相關(guān)推薦
- 2022-06-02 C語言超詳細(xì)梳理排序算法的使用_C 語言
- 2022-03-29 關(guān)于使用Redisson訂閱數(shù)問題_Redis
- 2022-10-21 解決Git?Revert?再次合代碼無效問題_相關(guān)技巧
- 2022-09-22 git-lfs 離線安裝
- 2022-10-27 python使用pika庫調(diào)用rabbitmq交換機模式詳解_python
- 2023-04-16 C#使用IronPython調(diào)用Python的實現(xiàn)_C#教程
- 2023-10-11 MyBatis-plus wrapper.and用法 | apply
- 2022-02-10 Error: Cannot find module ‘webpack/lib/RuleSet‘ 解決
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支