外排序的介绍、实现、数据测试

外排序的概念

1. 维基百科->外排序

http://zh.wikipedia.org/wiki/%E5%A4%96%E6%8E%92%E5%BA%8F

 

2. 《数据结构、算法与应用:C++语言实现》美·Sartaj Sahni(萨尔塔-萨尼)

-> 第10章(提到赢者树、败者树的概念)

赢者树、败者树都是选择树(Selection Tree / Tournament Tree)的一种。

 

通过上述两个途径,可以了解外排序的大致思路和过程。

 

外排序实现

使用赢者树的外部排序

http://www.blogjava.net/javacap/archive/2007/12/16/168034.html

 

其中CreateFile类,有一个main方法,执行它,可以生成一个40MB的含有随机数据的文本文件

ExternalSorter类,也有一个main方法,执行它,将对上述产生的文本文件进行排序,得到一个有序的文件。

 

 

后续研究

赢者树可以解决的一道Google面试题:

Describe analgorithm to find the largest 1 million numbers in 1 billion numbers. Assume thatthe computer memory can hold all one billion numbers.

 

寻找最大k个数问题

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值