计数排序

计数排序(Counting Sort)是一种O(n)的排序算法,其思路是开一个长度为maxValue-minValue+1的数组,然后
分配。扫描一遍原始数组,以当前值-minValue作为下标,将该下标的计数器增1。
收集。扫描一遍计数器数组,按顺序把值收集起来。
举个例子,nums=[2, 1, 3, 1, 5], 首先扫描一遍获取最小值和最大值,maxValue=5, minValue=1,于是开一个长度为5的计数器数组counter,
分配。统计每个元素出现的频率,得到counter=[2, 1, 1, 0, 1],例如counter[0]表示值0+minValue=1出现了2次。
收集。counter[0]=2表示1出现了两次,那就向原始数组写入两个1,counter[1]=1表示2出现了1次,那就向原始数组写入一个2,依次类推,最终原始数组变为[1,1,2,3,5],排序好了。
计数排序本质上是一种特殊的桶排序,当桶的个数最大的时候,就是计数排序。

extension Array where Element == Int {
    mutating func counterSort() -> Array{
        guard let max = self.max(),
              let min = self.min()
        else { return []}

        let range = max - min + 1
        var counter = Array<Element>(repeating: 0, count: range)
        
        for item in self {
            let index = item - min
            counter[index] += 1
        }
        var newArr = Array<Element>()
        for (index, item) in counter.enumerated() {
            var i = item
            while i > 0 {
                newArr.append(index + min)
                i -= 1
            }
        }
        return newArr
    }
}
引用

计数排序

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 数据结构与算法——计数排序、桶排序、基数排序 计数排序 计数排序有如下四个步骤。 首先会对每个输入进行频率统计,得...
    sunhaiyu阅读 4,903评论 0 11
  • /*今天的主要内容:1、桶排序、计数排序的介绍2、求排序后的数组相邻两个数的最大差值3、用数组实现大小固定的队列和...
    须臾之北阅读 4,245评论 0 0
  • 小撒是一只好学的小鸭子,这天,小撒在学习算法 比较排序与线性时间排序 此前我们介绍的排序方法都是基于比较的,而基于...
    笨笨小撒阅读 3,880评论 0 1
  • 计数排序 计数排序是一个非基于比较的排序算法,优势在于在对一定范围内的整数排序时,快于基于比较的排序算法。 算法思...
    风筝flying阅读 6,833评论 0 3
  • "不要轻易跟人家发生关系?没有了就是没有了。" 这是A女士能记得的,妈妈,唯一教给她的性观念。 关于身体发育与性发...
    米勒Li阅读 7,970评论 0 5

友情链接更多精彩内容