从一亿个数中找出最大的一万个数或最小的一万个数
2016-03-03 10:07
246 查看
1 从一亿个数中找出最大的一万个数:(前10000个元素构建最小堆,后续元素与根节点比较,大于放进去,小于或等于不处理)
用前一万个数初始化一个固定大小为10000的最小堆,这时根节点是这10000个数里最小的一个。
把后续的数依次与最小堆的根节点比较,如果大于则放进最小堆(这个操作同时会弹出一个元素并改变根节点),小于等于不做处理。
这个算法的复杂度几乎接近于O(n)
2 从一亿个数中找出最小的一万个数:(前10000个元素构建最大堆,后续元素与根节点比较,小于放进去,大于或等于不处理)
用前一万个数初始化一个固定大小为10000的最大堆,这时根节点是这10000个数里最大的一个。
把后续的数依次与最大堆的根节点比较,如果小于则放进最大堆(这个操作同时会弹出一个元素并改变根节点),大于等于不做处理。
这个算法的复杂度几乎接近于O(n)
用前一万个数初始化一个固定大小为10000的最小堆,这时根节点是这10000个数里最小的一个。
把后续的数依次与最小堆的根节点比较,如果大于则放进最小堆(这个操作同时会弹出一个元素并改变根节点),小于等于不做处理。
这个算法的复杂度几乎接近于O(n)
2 从一亿个数中找出最小的一万个数:(前10000个元素构建最大堆,后续元素与根节点比较,小于放进去,大于或等于不处理)
用前一万个数初始化一个固定大小为10000的最大堆,这时根节点是这10000个数里最大的一个。
把后续的数依次与最大堆的根节点比较,如果小于则放进最大堆(这个操作同时会弹出一个元素并改变根节点),大于等于不做处理。
这个算法的复杂度几乎接近于O(n)
相关文章推荐
- 解决springmvc ResponseBody请求返回406的问题
- 滴滴快车奖励政策,高峰奖励,翻倍奖励,按成交率,指派单数分级(3月3日)
- .Net Discovery 系列之一--string从入门到精通(上)
- 【python】将一个正整数分解质因数
- 客户端JS检测方法集合
- 使用StingBuffer、StringBuild、substring、replace对字符串的增加,删除 ,逆序输入
- 技术分享
- Android 自定义dialog,去除系统默认黑色背景,边框并设置dialog的显示位置
- stsiLdekniLowTfonoitcesretnI.160
- MATROSKA文件格式之Segments学习
- 支持向量机通俗导论(理解SVM的三层境界)
- 这次真真的不能再懒惰了!
- Entity Framework一对多关系添加数据的两种方式
- 【设计模式】15.解释器模式
- 网站用户行为数据挖掘
- symbol not found 是怎么回事啊?
- 千兆以太网的物理层
- Git for windows 中文乱码解决方案
- 《从零开始学Swift》学习笔记(Day 38)——构造函数与存储属性初始化
- css3兼容IE8的方案 各个ie的hack