※ 引述《FRAXIS (喔喔)》之铭言:
: 问题:给定 n 个已排序整数阵列,每个阵列长度为 n
: 找出 n^2 个元素中的中位数。
: 在网络上有找到几个讨论
: http://ppt.cc/PMvU
: http://ppt.cc/JE1s
: (这是变形,给定一个n by n矩阵,每行每列都排序,找中位数)
: 但是我觉得他们的解法到最后都变成O(n^2 lg n)。
: 而如果忽略掉每个阵列都已经排序的性质,直接在 n^2 个元素中找中位数,
: 因为找中位数可以在线性时间内完成,
: 所以在 n^2 个元素内找中位数只需要O(n^2)的时间,也比网页上的解答好。
: 有没有比O(n^2)快的方法来解决这问题呢?
应该很难吧!
资料有 n^2 笔,然后时间复杂度是 O(n^2),基本上已经是 linear time
要低于线性时间
要嘛略过一些资料
要嘛问题本身有很强的数学性质,可以直接推导答案
在这个问题当中,上面两种策略似乎都行不太通
考虑 median-of-median algorithm 的第一回合
由于给定资料是 n 条已排序阵列,所以第一回合可以省下很多工夫,可以很快做完
但是找到中位数的中位数之后
接下来,还有可能是中位数的资料,约占全部的3/4
第二回合还是得处理 3/4 * n^2 这么多资料,依旧是 O(n^2) 级别
即便我们已经知道 n 条已排序阵列,但是它的功效只能帮助我们略过 1/4 的资料
再加上中位数没有什么好的数学性质,尤其是可以用于精确计算的的数学性质
所以我觉得很难达成!