C++深入淺出講解希爾排序算法的實(shí)現(xiàn)
插入排序分為兩種:直接插入排序&希爾排序
希爾排序
1.基本思想
希爾排序是在直接插入排序基礎(chǔ)上的優(yōu)化,屬于非常牛掰的一個(gè)排序。
核心思想:
- 先進(jìn)行預(yù)排序,讓數(shù)組接近有序;
- 直接插入排序
預(yù)排序
預(yù)排序步驟:
分組排,假設(shè)gap==3,間隔為gap的為一組,然后分別使用插入排序的思想對(duì)這gap組數(shù)據(jù)進(jìn)行排序

多組間隔為gap的預(yù)排序,gap由大變小,gap越大,大的數(shù)可以越快的到后面,小的數(shù)可以越快得到前面,gap越大,預(yù)排完越不接近有序,gap越小,預(yù)排完越接近有序,gap為1時(shí)就是直接插入排序
動(dòng)圖演示:

預(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)的寫(xiě)法
{
//跟直接插入排序很像,不同的是需要使用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;
}
}
這是最初的寫(xiě)法,其實(shí)這個(gè)代碼是可以優(yōu)化的:
//預(yù)排序優(yōu)化
for (int i = 0; i < n - gap; i++)
//把間隔為gap的多組數(shù)據(jù)同時(shí)排
//當(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.算法實(shí)現(xiàn)
//希爾排序
void ShellSort(int* a, int n)
{
//一開(kāi)始初始化gap為n
int gap = n;
while (gap > 1)//gap大于1都是預(yù)排序,gap==1時(shí)為直接插入排序
{
//為保證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ù)同時(shí)排
//當(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.時(shí)間復(fù)雜度
希爾排序的時(shí)間復(fù)雜度是:O(N*logN)

到此這篇關(guān)于C++深入淺出講解希爾排序算法的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)C++希爾排序內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C++使用map實(shí)現(xiàn)多進(jìn)程拷貝文件的程序思路
這篇文章主要介紹了C++使用mmap實(shí)現(xiàn)多進(jìn)程拷貝文件,通過(guò)本文給大家分享程序思路及完整代碼,代碼簡(jiǎn)單易懂,對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-12-12
C語(yǔ)言學(xué)習(xí)之標(biāo)識(shí)符的使用詳解
C語(yǔ)言標(biāo)識(shí)符是用于表示變量、函數(shù)、常量、類型等程序元素的名稱,這篇文章將通過(guò)一些簡(jiǎn)單的示例為大家介紹一下C語(yǔ)言標(biāo)識(shí)符的使用,需要的可以參考一下2023-05-05
基于opencv實(shí)現(xiàn)視頻中的顏色識(shí)別功能
這篇文章主要介紹了基于opencv實(shí)現(xiàn)視頻中的顏色識(shí)別功能,文章詳細(xì)介紹了顏色識(shí)別的原理及opencv中的顏色模型,基于c++代碼實(shí)現(xiàn)顏色識(shí)別功能,需要的朋友可以參考下2022-07-07
C/C++ winsock實(shí)現(xiàn)不同設(shè)備實(shí)時(shí)通訊的示例代碼
這篇文章主要為大家詳細(xì)介紹了C/C++如何利用winsock連接實(shí)現(xiàn)不同設(shè)備實(shí)時(shí)通訊,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2023-09-09
C語(yǔ)言結(jié)構(gòu)體詳細(xì)圖解分析
C 數(shù)組允許定義可存儲(chǔ)相同類型數(shù)據(jù)項(xiàng)的變量,結(jié)構(gòu)是 C 編程中另一種用戶自定義的可用的數(shù)據(jù)類型,它允許你存儲(chǔ)不同類型的數(shù)據(jù)項(xiàng),本篇讓我們來(lái)了解C 的結(jié)構(gòu)體2022-03-03
實(shí)例詳解C/C++中extern關(guān)鍵字
這篇文章主要介紹了C/C++中extern關(guān)鍵字詳解 的相關(guān)資料,需要的朋友可以參考下2016-04-04

