欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C++深入淺出講解希爾排序算法的實現(xiàn)

 更新時間:2022年05月18日 10:41:34   作者:安然無虞  
希爾排序是希爾(Donald Shell)于1959年提出的一種排序算法。希爾排序也是一種插入排序,它是簡單插入排序經(jīng)過改進之后的一個更高效的版本,也稱為縮小增量排序,同時該算法是沖破O(n2)的第一批算法之一。本文會以圖解的方式詳細介紹希爾排序的基本思想及其代碼實現(xiàn)

插入排序分為兩種:直接插入排序&希爾排序

希爾排序

1.基本思想

希爾排序是在直接插入排序基礎(chǔ)上的優(yōu)化,屬于非常牛掰的一個排序。

核心思想:

  • 先進行預(yù)排序,讓數(shù)組接近有序;
  • 直接插入排序

預(yù)排序

預(yù)排序步驟:

分組排,假設(shè)gap==3,間隔為gap的為一組,然后分別使用插入排序的思想對這gap組數(shù)據(jù)進行排序

多組間隔為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),先排紅,再排綠,最后排藍
			//注意內(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)

到此這篇關(guān)于C++深入淺出講解希爾排序算法的實現(xiàn)的文章就介紹到這了,更多相關(guān)C++希爾排序內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C++使用map實現(xiàn)多進程拷貝文件的程序思路

    C++使用map實現(xiàn)多進程拷貝文件的程序思路

    這篇文章主要介紹了C++使用mmap實現(xiàn)多進程拷貝文件,通過本文給大家分享程序思路及完整代碼,代碼簡單易懂,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-12-12
  • C語言學(xué)習(xí)之標識符的使用詳解

    C語言學(xué)習(xí)之標識符的使用詳解

    C語言標識符是用于表示變量、函數(shù)、常量、類型等程序元素的名稱,這篇文章將通過一些簡單的示例為大家介紹一下C語言標識符的使用,需要的可以參考一下
    2023-05-05
  • 深入內(nèi)存對齊的詳解

    深入內(nèi)存對齊的詳解

    本篇文章是對內(nèi)存對齊進行了詳細的分析介紹,需要的朋友參考下
    2013-05-05
  • C++實現(xiàn)字符串刪除字符后逆序輸出

    C++實現(xiàn)字符串刪除字符后逆序輸出

    這篇文章主要為大家詳細介紹了C++實現(xiàn)字符串刪除字符后逆序輸出,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-05-05
  • 基于opencv實現(xiàn)視頻中的顏色識別功能

    基于opencv實現(xiàn)視頻中的顏色識別功能

    這篇文章主要介紹了基于opencv實現(xiàn)視頻中的顏色識別功能,文章詳細介紹了顏色識別的原理及opencv中的顏色模型,基于c++代碼實現(xiàn)顏色識別功能,需要的朋友可以參考下
    2022-07-07
  • C/C++ winsock實現(xiàn)不同設(shè)備實時通訊的示例代碼

    C/C++ winsock實現(xiàn)不同設(shè)備實時通訊的示例代碼

    這篇文章主要為大家詳細介紹了C/C++如何利用winsock連接實現(xiàn)不同設(shè)備實時通訊,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2023-09-09
  • C語言結(jié)構(gòu)體詳細圖解分析

    C語言結(jié)構(gòu)體詳細圖解分析

    C 數(shù)組允許定義可存儲相同類型數(shù)據(jù)項的變量,結(jié)構(gòu)是 C 編程中另一種用戶自定義的可用的數(shù)據(jù)類型,它允許你存儲不同類型的數(shù)據(jù)項,本篇讓我們來了解C 的結(jié)構(gòu)體
    2022-03-03
  • 實例詳解C/C++中extern關(guān)鍵字

    實例詳解C/C++中extern關(guān)鍵字

    這篇文章主要介紹了C/C++中extern關(guān)鍵字詳解 的相關(guān)資料,需要的朋友可以參考下
    2016-04-04
  • C++如何有效地利用命名空間

    C++如何有效地利用命名空間

    談到C++編程中的模塊化和組織性時,命名空間(Namespace)是一個重要的概念,所以本文主要來和大家聊聊C++命名空間的概念、用法以及如何有效地利用它來管理代碼,有需要的可以參考下
    2023-09-09
  • C++17之std::visit的具體使用

    C++17之std::visit的具體使用

    本文主要介紹了C++17之std::visit的具體使用,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-02-02

最新評論