问题描述
|
给定磁盘上的数万亿实数序列...
您将如何计算跑步
每千个条目的中位数,即
第一点是
a [0],....,a [999],
第二点是
a [1],...,a [1000],
第三点是
a [2],...,a [1001]等。
解决方法
天真的解决方案实际上还不错,在内存中保留了1000个数字的排序列表,每次您移至下一个索引时,从排序列表中删除
a[i-1]
,并将ѭ1list添加到排序列表中。
一旦有了它,就可以很容易地计算排序列表中的中位数。
问题是您如何做得更好?
, 提示:保持最大堆存储最小的1000个数字,并保持最小堆存储最大的500个数字。