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

C++插入排序算法實(shí)例詳解

 更新時間:2017年12月06日 11:49:32   作者:tttjp  
這篇文章主要為大家詳細(xì)介紹了C++插入排序算法實(shí)例,具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實(shí)例為大家分享了C++插入排序算法實(shí)例的具體代碼,供大家參考,具體內(nèi)容如下

基本思想

每次將一個待排序的元素,按其大小插入到已經(jīng)排好序的子序列的適當(dāng)位置,知道全部元素插入完成為止。

直接插入排序

1.排序思路

arr[0...i-1]為有序區(qū)(剛開始時i=1,有序區(qū)只有arr[0]一個元素),arr[i...size]為待排序區(qū),每次將待排序區(qū)的第一個元素arr[i]插入到有序區(qū)中的適當(dāng)位置,每趟操作都使有序區(qū)增加一個元素,待排序區(qū)減少一個元素。

2.排序算法

void InsertSort(int* arr, int size) 
{ 
  if (arr == NULL) 
    return; 
 
  for (int i = 1; i < size; i++) 
  { 
    //1.保存要排序的數(shù) 
    int tmp = arr[i];   
    //2.去有序區(qū)尋找該數(shù)應(yīng)該插入的位置 
    int j = i - 1; 
    while (j >= 0 && tmp < arr[j]) 
    { 
      //3.把有序區(qū)的位置一個一個往后移 
      arr[j + 1] = arr[j]; 
      j--; 
    } 
    arr[j + 1] = tmp; 
  } 
} 

3.算法分析

直接插入排序由兩重循環(huán)構(gòu)成,外循環(huán)進(jìn)行n-1次。
若初始數(shù)據(jù)序列遞增有序即為正序時,每一趟排序不進(jìn)入內(nèi)循環(huán),僅進(jìn)行一次大小比較。此時元素移動次數(shù)為2次(tmp = arr[i]和arr[j+1] = tmp)。所以正序時比較次數(shù)和元素移動次數(shù)均達(dá)到最小值Cmin和Mmin:

Cmin = n-1
Mmin = 2(n-1)

若初始數(shù)據(jù)序列遞減有序即為逆序時,因當(dāng)前有序區(qū)的元素均大于待排序區(qū)的元素,所以需要將待插入元素與arr[0...i-1]中全部元素進(jìn)行比較,這需要進(jìn)行i次比較;內(nèi)循環(huán)中需將arr[0...i-1]中所有元素后移(i-1)-0+1 = i次,外加tmp = arr[i]和arr[j+1] = tmp的兩次移動,一趟排序所需的元素移動次數(shù)為i+2次。所以逆序時比較次數(shù)和元素移動次數(shù)均達(dá)到最da值Cmax和Mmax:

Cmax = n(n-1) / 2
Mmax = (n-1)(n+4) / 2

正序時直接插入排序算法的時間復(fù)雜度為O(N),逆序時直接插入排序算法的時間復(fù)雜度為O(N^2)。
故直接插入排序算法的時間復(fù)雜度為O(N^2)。由于只使用了i、j、tmp三個輔助變量,故空間復(fù)雜度為O(1)。
當(dāng)i > j且arr[i] = arr[j]時,直接將arr[i]插入到arr[j]后,故直接插入排序是穩(wěn)定的。

折半插入排序(二分插入排序)

1.排序思路

采用折半查找方法先在arr[0...i-1]中找到插入位置,再通過移動元素進(jìn)行插入
2.排序算法

void InsertSort1(int* arr, int size) 
{ 
  if (arr == NULL) 
    return; 
 
  int i, j, low, high; 
  //1.保存要插入的數(shù) 
  for (i = 1; i < size; i++) 
  { 
    int tmp = arr[i]; 
    low = 0; 
    high = i - 1; 
    //2.折半查找插入位置(插入位置為high+1) 
    while (low <= high) 
    { 
      int mid = low + ((high - low) >> 1); 
      if (tmp < arr[mid]) 
        high = mid - 1; 
      else 
        low = mid + 1; 
    } 
    //3.元素后移,插入 
    for (j = i - 1; j >= high + 1; j--) 
    { 
      arr[j + 1] = arr[j]; 
    } 
    arr[j + 1] = tmp; 
  }   
} 

3.算法分析

當(dāng)初始數(shù)據(jù)序列為正序時,比較次數(shù)并不能減少;當(dāng)為逆序時,比較次數(shù)也不會增加。元素移動次數(shù)與直接插入排序相同。
故折半插入排序的時間復(fù)雜度為O(N^2),空間復(fù)雜度為O(1),是穩(wěn)定的。
就平均性能而言,折半查找優(yōu)于順序查找,所以折半插入排序優(yōu)于直接插入排序。

希爾排序

1.排序思路

希爾排序是一種分組插入排序。先取一個小于n的整數(shù)d1,作為第一個增量,序列被分為d1組,所有相互之間距離為d1的倍數(shù)的元素放在同一個組中,在各組內(nèi)進(jìn)行直接插入排序;然后取第二個增量d2(<d1),重復(fù)上述過程,直至增量為1。
希爾排序每趟并不產(chǎn)生有序區(qū),在最后一趟排序結(jié)束之前,所有元素并不一定歸位,每趟排完之后,數(shù)據(jù)越來越接近有序。

2.排序算法

void ShellSort(int* arr, int size) 
{ 
  if (arr == NULL) 
    return; 
 
  int i, j, gap; 
  //1.取gap 
  gap = size / 2; 
  while (gap > 0) 
  { 
    //2.分組比較 
    for (i = gap; i < size; i++) 
    { 
      int tmp = arr[i]; 
      //3.移動元素,插入 
      j = i - gap; 
      while (j >= 0 && tmp < arr[j]) 
      { 
        arr[j + gap] = arr[j]; 
        j -= gap; 
      } 
      arr[j + gap] = tmp; 
    } 
    gap = gap / 2; 
  } 
} 

3.算法分析

希爾排序算法的性能分析是一個復(fù)雜的問題,它的時間復(fù)雜度與所取gap有關(guān),一般認(rèn)為其時間復(fù)雜度為O(N^1.3),空間復(fù)雜度為O(1)。
希爾排序是一種不穩(wěn)定的算法。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • C++實(shí)現(xiàn)冒泡排序(BubbleSort)

    C++實(shí)現(xiàn)冒泡排序(BubbleSort)

    這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)冒泡排序,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-04-04
  • C++ 實(shí)現(xiàn)對象池的具體方法

    C++ 實(shí)現(xiàn)對象池的具體方法

    本文主要介紹了C++ 實(shí)現(xiàn)對象池的具體方法,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-01-01
  • 基于Matlab實(shí)現(xiàn)抖音小游戲蘋果蛇

    基于Matlab實(shí)現(xiàn)抖音小游戲蘋果蛇

    最近抖音上蘋果蛇小游戲大火,為了證明MATLAB無所不能,咋能不跟風(fēng)做一個?文中詳細(xì)講解了游戲的實(shí)現(xiàn)步驟,感興趣的小伙伴可以嘗試一下
    2022-06-06
  • C++中NULL與nullptr的區(qū)別對比

    C++中NULL與nullptr的區(qū)別對比

    nullptr是c++11中的關(guān)鍵字,下面這篇文章主要介紹了C++中NULL與nullptr區(qū)別的相關(guān)資料,對大家來說還是挺實(shí)用的,需要的朋友可以參考下
    2021-05-05
  • C++解決大數(shù)組棧內(nèi)存不夠問題的方法分析

    C++解決大數(shù)組棧內(nèi)存不夠問題的方法分析

    這篇文章主要介紹了C++解決大數(shù)組棧內(nèi)存不夠問題的方法,結(jié)合實(shí)例形式對比分析了C++針對大數(shù)組棧內(nèi)存不足情況的常見解決方法及其優(yōu)缺點(diǎn),具有一定參考借鑒價值,需要的朋友可以參考下
    2018-05-05
  • 實(shí)例詳解C++中指針與引用的區(qū)別

    實(shí)例詳解C++中指針與引用的區(qū)別

    引用是C++引入的重要機(jī)制(C語言沒有引用),它使原來在C中必須用指針來實(shí)現(xiàn)的功能有了另一種實(shí)現(xiàn)的選擇,在書寫形式上更為簡潔,那么引用的本質(zhì)是什么,它與指針又有什么關(guān)系呢?這篇文章主要給大家介紹了關(guān)于C++中指針與引用的區(qū)別,需要的朋友可以參考下
    2021-07-07
  • VC多線程編程詳解

    VC多線程編程詳解

    這篇文章主要介紹了VC多線程編程,實(shí)例形式詳細(xì)分析了多線程編程的原理與實(shí)現(xiàn)方法,具有一定的參考借鑒價值,需要的朋友可以參考下
    2014-10-10
  • C/C++實(shí)現(xiàn)個人收支系統(tǒng)的示例代碼

    C/C++實(shí)現(xiàn)個人收支系統(tǒng)的示例代碼

    這篇文章主要介紹了C/C++實(shí)現(xiàn)個人收支系統(tǒng),本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-06-06
  • 在C++中自定義宏的簡單方法

    在C++中自定義宏的簡單方法

    這篇文章主要介紹了在C++中自定義宏的簡單方法,作者建議使用類似定義函數(shù)一樣的方法來定義宏,需要的朋友可以參考下
    2015-07-07
  • 淺析C++編程當(dāng)中的線程

    淺析C++編程當(dāng)中的線程

    這篇文章主要介紹了淺析C++編程當(dāng)中的線程,線程在每一種編程語言中都是重中之重,需要的朋友可以參考下
    2015-07-07

最新評論