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

C++ 計(jì)數(shù)排序?qū)嵗斀?/h1>
 更新時(shí)間:2017年07月06日 08:42:20   投稿:lqh  
這篇文章主要介紹了C++ 計(jì)數(shù)排序?qū)嵗斀獾南嚓P(guān)資料,需要的朋友可以參考下

計(jì)數(shù)排序

             計(jì)數(shù)排序是一種非比較的排序算法

優(yōu)勢(shì):

             計(jì)數(shù)排序在對(duì)于一定范圍內(nèi)的整數(shù)排序時(shí),時(shí)間復(fù)雜度為O(N+K)  (K為整數(shù)在范圍)快于任何比較排序算法,因?yàn)榛诒容^的排序時(shí)間復(fù)雜度在理論上的上下限是O(N*log(N))。

缺點(diǎn):

             計(jì)數(shù)排序是一種犧牲空間換取時(shí)間的做法,并且當(dāng)K足夠大時(shí)O(K)>O(N*log(N)),效率反而不如比較的排序算法。并且只能用于對(duì)無(wú)符號(hào)整形排序。

時(shí)間復(fù)雜度:

            O(N)  K足夠大時(shí)為O(K)

空間復(fù)雜度:

           O(最大數(shù)-最小數(shù))

性能:

           計(jì)數(shù)排序是一種穩(wěn)定排序

代碼實(shí)現(xiàn):

#include <iostream> 
#include <Windows.h> 
#include <assert.h> 
 
using namespace std; 
 
//計(jì)數(shù)排序,適用于無(wú)符號(hào)整形 
void CountSort(int* a, size_t size) 
{ 
  assert(a); 
  size_t max = a[0]; 
  size_t min = a[0]; 
  for (size_t i = 0; i < size; ++i) 
  { 
    if (a[i] > max) 
    { 
      max = a[i]; 
    } 
    if (a[i] < min) 
    { 
      min = a[i]; 
    } 
  } 
  size_t range = max - min + 1;   //要開(kāi)辟的數(shù)組范圍 
  size_t* count = new size_t[range]; 
  memset(count, 0, sizeof(size_t)*range);  //初始化為0 
  //統(tǒng)計(jì)每個(gè)數(shù)出現(xiàn)的次數(shù) 
  for (size_t i = 0; i < size; ++i)   //從原數(shù)組中取數(shù),原數(shù)組個(gè)數(shù)為size 
  { 
    count[a[i]-min]++; 
  } 
  //寫(xiě)回到原數(shù)組 
  size_t index = 0; 
  for (size_t i = 0; i < range; ++i)  //從開(kāi)辟的數(shù)組中讀取,開(kāi)辟的數(shù)組大小為range 
  { 
    while (count[i]--) 
    { 
      a[index++] = i + min; 
    } 
  } 
  delete[] count; 
} 
 
void Print(int* a, size_t size) 
{ 
  for (size_t i = 0; i < size; ++i) 
  { 
    cout << a[i] << " "; 
  } 
  cout << endl; 
} 
#include "CountSort.h" 
 
void TestCountSort() 
{ 
  int arr[] = { 1, 2, 3, 4, 5, 6, 6, 6, 6, 6, 6, 6, 6, 6, 2, 2, 2, 4, 5, 8, 9, 5, 11, 11, 22, 12, 12 }; 
  size_t size = sizeof(arr) / sizeof(arr[0]); 
  CountSort(arr, size); 
  Print(arr, size); 
} 
 
int main() 
{ 
  TestCountSort(); 
  system("pause"); 
  return 0; 
} 


感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!

您可能感興趣的文章:

相關(guān)文章

  • Java?C++?leetcode面試零矩陣

    Java?C++?leetcode面試零矩陣

    這篇文章主要為大家介紹了Java?C++題解leetcode面試零矩陣示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-10-10
  • C++基于easyx實(shí)現(xiàn)迷宮游戲

    C++基于easyx實(shí)現(xiàn)迷宮游戲

    這篇文章主要為大家詳細(xì)介紹了C++基于easyx實(shí)現(xiàn)迷宮游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • Qt串口通信開(kāi)發(fā)之QSerialPort模塊簡(jiǎn)單使用方法與實(shí)例

    Qt串口通信開(kāi)發(fā)之QSerialPort模塊簡(jiǎn)單使用方法與實(shí)例

    這篇文章主要介紹了Qt串口通信開(kāi)發(fā)之QSerialPort模塊簡(jiǎn)單使用方法與實(shí)例,需要的朋友可以參考下
    2020-03-03
  • C++獲取項(xiàng)目路徑的兩種方式詳解

    C++獲取項(xiàng)目路徑的兩種方式詳解

    這篇文章主要介紹了C++獲取項(xiàng)目路徑的兩種方式的相關(guān)資料,需要的朋友可以參考下,希望能夠給你帶來(lái)幫助
    2021-10-10
  • OpenCV實(shí)現(xiàn)馬賽克和毛玻璃濾鏡效果

    OpenCV實(shí)現(xiàn)馬賽克和毛玻璃濾鏡效果

    這篇文章主要為大家詳細(xì)介紹了OpenCV實(shí)現(xiàn)馬賽克和毛玻璃濾鏡效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-01-01
  • LZ77壓縮算法原理的理解

    LZ77壓縮算法原理的理解

    這篇文章主要介紹了LZ77壓縮算法原理的理解的相關(guān)資料,數(shù)據(jù)壓縮是一個(gè)減小數(shù)據(jù)存儲(chǔ)空間的過(guò)程,目前被應(yīng)用在軟件工程的各個(gè)地方,了解其一些原理,方便我們更好的甄選壓縮方案,需要的朋友可以參考下
    2017-08-08
  • QT與MATLAB混合編程的詳細(xì)教程

    QT與MATLAB混合編程的詳細(xì)教程

    最近項(xiàng)目需要,matlab的一些算法需要工程用,因此需要直接轉(zhuǎn)成Qt能夠調(diào)用的形式,下面這篇文章主要給大家介紹了關(guān)于QT與MATLAB混合編程的相關(guān)資料,需要的朋友可以參考下
    2023-01-01
  • C語(yǔ)言操作符超詳細(xì)講解下篇

    C語(yǔ)言操作符超詳細(xì)講解下篇

    C?語(yǔ)言提供了豐富的操作符,有:算術(shù)操作符,移位操作符,位操作符,賦值操作符,單目操作符,關(guān)系操作符,邏輯操作符,條件操作符等。本篇為第二篇,讓我們通讀本篇來(lái)詳細(xì)了解吧
    2022-04-04
  • C++模擬如何實(shí)現(xiàn)vector

    C++模擬如何實(shí)現(xiàn)vector

    這篇文章主要介紹了C++模擬如何實(shí)現(xiàn)vector問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • C語(yǔ)言直接插入排序算法介紹

    C語(yǔ)言直接插入排序算法介紹

    大家好,本篇文章主要講的是C語(yǔ)言直接插入排序算法介紹,感興趣的同學(xué)趕快來(lái)看一看吧,對(duì)你有幫助的話記得收藏一下,方便下次瀏覽
    2021-12-12

最新評(píng)論