美文网首页
2020-01-29 桶排序

2020-01-29 桶排序

作者: 人拆 | 来源:发表于2020-01-29 14:35 被阅读0次
document.write("<script src='./插入排序.js'> </script>")

function bucketSort(arr, bucketSize = 5) {
  const len = arr.length
  if (len <= 1) return arr

  const buckets = createBuckets(arr, bucketSize)
  return sortBuckets(buckets)
}

function createBuckets(arr, bucketSize) {
  const len = arr.length
  let minVal = arr[0]
  let maxVal = arr[0]
  // 遍历数组,找到数组最小值与数组最大值
  for (let i = 1; i < len; i++) {
    if (arr[i] < minVal)
      minVal = arr[i]
    if (arr[i] > maxVal)
      maxVal = arr[i]
  }
  // 根据最小值、最大值、桶的大小,计算得到桶的个数
  const bucketCount = ~~((maxVal - minVal) / bucketSize) + 1
  // 建立一个二维数组,将桶放入buckets中
  const buckets = []
  for (let i = 0; i < bucketCount; i++) {
    buckets[i] = []
  }
  // 计算每一个值应该放在哪一个桶中
  for (let i = 0; i < arr.length; i++) {
    const bucketIndex = ~~((arr[i] - minVal) / bucketSize)
    buckets[bucketIndex].push(arr[i])
  }
  return buckets
}

function sortBuckets(buckets) {
  const sortedArray = []
  for (let i = 0; i < buckets.length; i++) {
    if (buckets[i] != null) {
      insertionSort(buckets[i]) // 每个桶里排序,这里用了插入排序
      sortedArray.push(...buckets[i])
    }
  }
  return sortedArray
}

相关文章

  • 2020-01-29 桶排序

  • 算法基础 排序(一)

    桶排序冒泡排序快速排序 1.桶排序 所谓的桶排序就是列出所有的可能进行排序 小结:这里的桶排序只是简化版的.桶排序...

  • 《数据结构与算法之美》10——排序(三)桶排序、计数排序、基数排

    桶排序 概念 桶排序,核心思想是将要排序的数据分到几个有序的桶里,每个桶里的数据再单独进行排序。桶内排序之后,再把...

  • 桶排序

    什么是桶排序桶排序是计数排序的衍化桶排序需要创建若干个桶来装元素协助排序。每一个桶(bucket)代表一个区间范围...

  • 桶排序,计数排序和基数排序

    桶排序 桶排序的核心思路 桶排序的核心处理思想是先定义几个有序的桶,将要排序的数组按照桶划分的值的范围分到这几个桶...

  • 桶排序与哈希桶排序

    一.桶排序 算法原理 桶排序 (箱排序)的原理是将待排序序列分到有限数量的桶里面,然后对每个桶再分别排序(可以使用...

  • php-计数排序、基数排序、桶排序

    计数排序、基数排序、桶排序 时间复杂度 O(n) 计数排序 基数排序 桶排序

  • 数组-桶排序

    采用桶排序方式对数组进行排序 桶排序百科:桶排序(Bucket Sort),或者所谓的箱排序是一种非比较排序.工作...

  • 13|桶排序

    桶排序( Bucket sort )首先,我们来看桶排序。桶排序,顾名思义,会用到 “ 桶 ” ,核心思想是将要排...

  • 线性排序

    桶排序 核心思想是将要排序的数据分到几个有序的桶里,每个桶里的数据再单独进行排序。桶内排序完之后,再把每个桶里的数...

网友评论

      本文标题:2020-01-29 桶排序

      本文链接:https://www.haomeiwen.com/subject/cvwvthtx.html