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

桶排序

桶排序的核心思路

  • 桶排序的核心处理思想是先定义几个有序的桶,将要排序的数组按照桶划分的值的范围分到这几个桶中,对每个桶的数据单独进行排序。再把每个桶里的数据按照顺序依次取出,组成的序列就是有序的。

桶排序的操作流程

  • 比如要排序的数据有n个,我们划分出m个桶,将数据按照划分的值范围分别划分到对应桶中。然后单独对桶内的数据进行排序,可以采用任何排序算法,总之就是将桶内数据排好序。
  • 排好了各个桶内的数据之后。再按顺序依次将桶内的数据取出,合并成一个整体,就排好序了。

桶排序的相关

  • 桶排序比较适合用在外部排序中。即数组存储在外部磁盘,数据量比较大而内存有限,无法将全部数据加载到内存中处理。
  • 桶排序的平均时间复杂度为O(n+k),k为数据范围。
  • 桶排序不是原地排序,是否是稳定排序就得看桶内排序时使用的排序算法是否是稳定排序算法了。
  • 桶排序对排序数据有一定的特殊要求。待排数据很容易被划分成m个桶,并且桶和桶之间有着天然的大小顺序,这样每个桶内的数据排序完成之后,桶与桶之间的数据不需要再次进行排序。

计数排序

计数排序的核心思路

  • 计数排序是桶排序的一种特殊情况。当要排序的n个数据所处的范围并不大的时候,如最大值为k,则可以将数据划分为k个桶,每个桶中的数据是相等的,省掉了桶内数据排序的时间。

计数排序的操作流程

  • 假设一次考试满分为100分。我们可以将所有考生的考试成绩划分为101个桶,每个桶依次表示0到100分。然后遍历数据,将对应分数的考生直接划分到对应分数的桶中。这样每个桶中所有的考生的分数都是相同的,就不再需要排序了。如果需要计算考生的名次或者分数段内考生的数量,就直接对桶的数据量进行运算就可以得出了。
  • 如果我们要对这些考试数据进行排序,获得考生再有序数组中的具体位置。所有考生数据的一个数组为c[n],则我们再创建一个数组a[101],其中数组的下标对应的是分数,数组存储的数据对应的是考了这个分数的学生数量。
  • 用一个比较巧妙的处理思路:对数组a[101]顺序累加求和。即a[0]=a[0],a[1]=a[0]+a[1],a[2]=a[1]+a[2],类似这种操作。做完这个操作,数组a就改变了表示的含义。此时数组a的下标仍然是表示的分数,而数组a装的数据则表示的是所有考了小于等于以当前下标为分数的考生个数。
  • 然后我们创建一个和c[n]一样大小的数组temp,用于存放排好序的数据。对c[n]所有学生数据的数组从后向前遍历,遍历到c[n-1],取出来当前考生的分数是score,这个分数对应的就是a[101]数组的下表,取出a[score],此时就取出了考了小于等于这个分数的学生个数k。此时我们就可以将这个学生放入到temp[k-1]的位置。此时我们就排好了这个学生的位置,然后将a[score]=k-1,代表剩余的未排序的学生数组中还剩下k-1个学生分数小于等于score分。
  • 注意:这里为什么要从后向前遍历学生数组c[n],是因为后续插入到temp中时也是在这个分数区间内插入到的区间末尾。这样才是稳定排序。

计数排序的相关

  • 计数排序对数据有限制。1.数据范围不能太大,太大了如果数据范围k比需要排序的数据个数n还要大很多,那就不适用计数排序了。2.计数排序只能给非负整数排序,如果是有小数点,则需要都乘到整数位。如果存在负数,则需要都加到正数才可。因为计数排序不是对数据的比较,而是对数据的数量的计算之后对数据的排序,用到了数据下标的方法。
  • 计数排序不是原地排序,是稳定排序。
  • 计数排序的平均时间复杂度是O(n)。

基数排序

基数排序的核心思想

  • 基数排序的核心思想就是将数据划分成高低位,然后再借助桶排序或者计数排序去完成每一位的排序工作。

基数排序的操作流程

  • 排序手机号码,可以划分成每一位去排序。
  • 排序英文单词,可以利用用0补全,再分别取每一位字母去对比排序。

基数排序的相关

  • 基数排序对数据有一定的要求,要求数据必须可以划分成高低位,并且位之间是有递进关系的。
  • 每一位的数据范围不能太大,因为基数排序需要借助桶排序或者计数排序来完成每一位的排序工作。
  • 基数排序的平均时间复杂度是O(dn),d为数据维度。
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,657评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,662评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,143评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,732评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,837评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,036评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,126评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,868评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,315评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,641评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,773评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,859评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,584评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,676评论 2 351

推荐阅读更多精彩内容