中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

基數排序與基數排序

發布時間:2020-07-06 16:45:35 來源:網絡 閱讀:365 作者:腳印C 欄目:編程語言

基數排序與基數排序是兩種非比較型排序。


計數排序:


//************計數排序*********
//先最大-最小+1得到開辟空間數,開辟空間str,在遍歷原數據arr在str相應位置計數,再遍歷str將值寫到原arr中
//適用在密集型數據, 無重復最優可轉化為位圖
//時間復雜度O(N),空間復雜度O(最大數-最小數+1)

//設數組元素非負
void CountingSort(int *a, size_t size)
{
 size_t i = 0, j = 0;
 int max = a[0], min = a[0];
 size_t space = 0;
 for (i = 1; i < size; i++)
 {
  if (max < a[i])
  {
   max = a[i];
  }
  if (min > a[i])
  {
   min = a[i];
  }
 }
 space = max - min + 1;
 //str相應位置記錄a中個數據的次數
 int *str = new int[space]();
 for (i = 0; i < size; i++)
 {
  str[a[i] - min] ++;
 }

 //寫回原數組a中
 for (i = 0, j = 0; i < space, j < size; i++)
 {
  while (str[i]-- > 0)
  {
   a[j++] = i + min;
  }

 }
}


基數排序:

基數排序與基數排序

//***********基數排序**************
//采用先排低位,在排高位
//時間復雜度O(位數) 空間復雜度O(N)

//設數組元素非負
size_t GetMaxRadix(int *a, size_t size)//取數組中最大值的位數
{
 assert(a != NULL);
 size_t i = 0;
 size_t num = 0;
 size_t count = 1;
 for (i = 0; i < size; i++)
 {
  while (a[i] / count>0)
  {
   count *= 10;
   num++;
  }
 }
 return num;
}


void LSDSort(int *a, size_t size)
{
 assert(a != NULL);
 int MaxRadix = GetMaxRadix(a, size);
 int count[10] = { 0 };//同一位上數字相等的數字個數
 int start[10] = { 0 };//按位上數字所對應的起始位置
 int * bucket = new int[size];
 size_t i = 0;
 int num = 1;
 while (MaxRadix--)
 {
  memset(count, 0, sizeof(int) * 10);//count清零
  //按位排序
  
  for (i = 0; i < size;i++)//count[]
  {
   count[a[i] / num % 10]++;//取某一位上數字,在count相應位置++
  }
  for (i = 0; i < 10; i++)//start[]
  {
   //跳過0 因為起始位置一定為0
   if (i == 0)
   {
    start[i] = 0;
   }
   else
    start[i] = start[i - 1] + count[i - 1];
  }

  //寫到bucket[]中
  for (i = 0; i < size; i++)
  {
   bucket[start[a[i] / num % 10]++] = a[i];
  }
  //寫回a[]中
  for (i = 0; i < size; i++)
  {
   a[i] = bucket[i];
  }
  num *= 10;
 }

}


test:

 int a5[] = { 5, 24, 35, 54, 72, 81, 75, 6, 9, 56, 114, 30, 5 };
 int a6[] = { 5, 24, 35, 54, 72, 81, 75, 6, 9, 56, 114, 30, 5 };

基數排序與基數排序

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

云林县| 阜阳市| 灵宝市| 岐山县| 于都县| 呼玛县| 绥滨县| 阜平县| 马公市| 永兴县| 福州市| 贡山| 盐亭县| 阜南县| 综艺| 衡山县| 边坝县| 牡丹江市| 白玉县| 赣榆县| 阳江市| 突泉县| 泸州市| 米泉市| 汝城县| 田阳县| 宝兴县| 乃东县| 曲麻莱县| 延吉市| 娱乐| 同心县| 桑日县| 金乡县| 惠来县| 泰顺县| 定日县| 漯河市| 健康| 沾化县| 申扎县|