博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
3、桶排序
阅读量:6115 次
发布时间:2019-06-21

本文共 715 字,大约阅读时间需要 2 分钟。

1、思路:

  ①、首先找到数组中的最大值,然后新建一个初始值为 0 的数组 bucket, 此数组的长度是数组最大值+1,新建的这个数组中的下标值存放的元素就是原数组的数据值。

  ②、找到最大值后,开始遍历原数组,把原数组的数据加入bucket的下表中,bucket[i],每当有1个i bucket[i]的值就加一, 然后已经装入桶后,
   
  ③、遍历桶,如果bucket[j]位置不是 0 就说明此下标有数据,也就是说,此下标在原数组里有这个值, 然后排序 就是从大到小了 arr[i++]=j;
2、优化
   创建 bucket 数组的大小为 (max - min) 即可。
 

3、 时间复杂度:O(N)

  额外空间复杂度:O(N)

  是否可实现稳定性:否

 

 4、运用实例: 

   Leetcode 164. Maximum Gap

  假设数组 nums 有N个元素min到max。

  那么每个桶的最大差值不会小于ceiling[(max - min) / (N - 1)]

  令最大差值就是 ceiling[(B - A) / (N - 1)]

  去除 nums 的 max、val 值后 nums 剩下 N - 2 个元素

  将他们放在 N - 1个桶中,且第 k 个桶存放的数值大小为 [min+ (k-1)gap, min+ k*gap).

   

 

5、基数排序:

    动画演示:

    运用: https://www.cnblogs.com/skillking/p/9789980.html

转载于:https://www.cnblogs.com/skillking/p/9788052.html

你可能感兴趣的文章
VC++文件拖拽功能实现drag
查看>>
LinuxCast Linux 使用RAID提升磁盘速度及冗余性 视频教程笔记
查看>>
雷人国产剧剧情
查看>>
Linux系统开机启动过程
查看>>
linux Mint 初次安装,无法用ssh客户端连接
查看>>
iOS 捕获全局异常,统一收集
查看>>
Mastering Symfony2 Performance – Doctrine
查看>>
Python模块之StringIO
查看>>
Cookie学习-------介绍
查看>>
Windows Server 2012 Hyper-V新特性(1)
查看>>
gifflen 调用以及错误处理
查看>>
华为的IPsec ×××(野蛮模式)
查看>>
查杀IPZ2.EXE病毒实战
查看>>
DHCP试验
查看>>
SAE Django如何禁止外部IP访问
查看>>
Eclilpse 开发Ext JS卡住
查看>>
JSP的两种include
查看>>
git@osc中协作开发、复制项目、贡献代码
查看>>
我的友情链接
查看>>
构建大型企业网络-访问控制列表(ACL)
查看>>