拜托,面试别再问我桶排序了!!!

简介: 排序,面试中考察基本功问的比较多的问题。

排序,面试中考察基本功问的比较多的问题。

时间复杂度为O(n)的排序,常见的有三种:

  • 基数排序(Radix Sort)
  • 计数排序(Counting Sort)
  • 桶排序(Bucket Sort)

今天,1分钟,争取让大家搞懂桶排序。

画外音:百度“桶排序”,很多文章是错误的,本文内容与《算法导论》中的桶排序保持一致。

桶排序的适用范围是,待排序的元素能够均匀分布在某一个范围[MIN, MAX]之间。

画外音:很多业务场景是符合这一场景,待排序的元素在某一范围内,且是均匀分布的。

桶排序需要两个辅助空间:

  • 第一个辅助空间,是桶空间B
  • 第二个辅助空间,是桶内的元素链表空间

总的来说,空间复杂度是O(n)。

桶排序有两个关键步骤:

扫描待排序数据A[N],对于元素A[i],放入对应的桶X

A[i]放入桶X,如果桶X已经有了若干元素,使用插入排序,将arr[i]放到桶内合适的位置

画外音:

(1)桶X内的所有元素,是一直有序的;

(2)插入排序是稳定的,因此桶内元素顺序也是稳定的;

当arr[N]中的所有元素,都按照上述步骤放入对应的桶后,就完成了全量的排序。

桶排序的伪代码是:

bucket_sort(A[N]){

     for i =1 to n{

           将A[i]放入对应的桶B[X];

           使用插入排序,将A[i]插入到B[X]中正确的位置;

     }

     将B[X]中的所有元素,按顺序合并,排序完毕;

}

举个栗子:

假设待排序的数组均匀分布在[0, 99]之间:

{5,18,27,33,42,66,90,8,81,47,13,67,9,36,62,22}

可以设定10个桶,申请额外的空间bucket[10]来作为辅助空间。其中,每个桶bucket[i]来存放[10i, 10i+9]的元素链表。

image.png

上图所示:

  • 待排序的数组为unsorted[16]
  • 桶空间是buket[10]
  • 扫描所有元素之后,元素被放到了自己对应的桶里
  • 每个桶内,使用插入排序,保证一直是有序的

例如,标红的元素66, 67, 62最终会在一个桶里,并且使用插入排序桶内保持有序。

最终,每个桶按照次序输出,排序完毕。

神奇不神奇!!!

桶排序(Bucket Sort),总结:

  • 桶排序,是一种复杂度为O(n)的排序
  • 桶排序,是一种稳定的排序
  • 桶排序,适用于数据均匀分布在一个区间内的场景

希望这一分钟,大家有收获。

架构师之路-分享可落地的技术文章

目录
相关文章
|
3月前
|
SQL 关系型数据库 MySQL
几道常见面试问题总结(二)
几道常见面试问题总结(二)
|
3月前
|
算法 前端开发 JavaScript
面试必会的几道算法
面试必会的几道算法
|
8月前
两道智力题
两道智力题
|
算法 索引
【牛客算法-二分查找】刷题和面试兼顾还得看你啊
【牛客算法-二分查找】刷题和面试兼顾还得看你啊
94 0
【牛客算法-二分查找】刷题和面试兼顾还得看你啊
|
存储 算法 索引
面试被问到线段树,已经这么卷了吗?
面试被问到线段树,已经这么卷了吗?
110 0
面试被问到线段树,已经这么卷了吗?
|
搜索推荐
面试官:给我手撕一下基数排序,再考虑一下如何进行改进呢?
到目前为止我已经把一些常见的排序算法进行了讲解。今天主要关注另外一个排序算法,叫做基数排序。 每天学一个知识点,一年之后就会有质的变化。
82 0
[刷题计划]第二周第六天|二分查找
[刷题计划]第二周第六天|二分查找
|
搜索推荐 算法 小程序
程序员面试必备之排序算法汇总(上)
本文用Python实现了快速排序、插入排序、希尔排序、归并排序、堆排序、选择排序、冒泡排序共7种排序算法。
542 2
程序员面试必备之排序算法汇总(上)
|
人工智能 搜索推荐 算法
程序员面试必备之排序算法汇总(下)
本文用Python实现了快速排序、插入排序、希尔排序、归并排序、堆排序、选择排序、冒泡排序共7种排序算法。上篇已经介绍了前三种~给出原文链接如下:程序员面试必备之排序算法汇总(上)
107 0
程序员面试必备之排序算法汇总(下)
|
存储 Java
难缠的面试八股文哈希冲突,这次通透了
哈喽,我是指北君。 最近有个读者后台私信指北君,说最近面试被问到了如何解决哈希冲突的问题,他只回答了链地址法(HashMap中就用的这种方法),但是面试官说还有其他的方案,于是想让小北解答下,说实话,当时小北也不知道。。。
难缠的面试八股文哈希冲突,这次通透了