java list 時間排序 一道java面試題,20億數(shù)字的文本排序,如何取前100?
一道java面試題,20億數(shù)字的文本排序,如何取前100?因為這是一個Java問題,所以這是典型的TOPK問題。首先取前100個數(shù)字構(gòu)建一個最小堆,然后依次從堆的頂部插入剩余的數(shù)字,同時調(diào)整堆。堆中最
一道java面試題,20億數(shù)字的文本排序,如何取前100?
因為這是一個Java問題,所以這是典型的TOPK問題。首先取前100個數(shù)字構(gòu)建一個最小堆,然后依次從堆的頂部插入剩余的數(shù)字,同時調(diào)整堆。堆中最后100個元素就是結(jié)果??臻g復雜度為k,時間復雜度為nlogk
您可以完成執(zhí)行列表.addAll(空白列表),然后執(zhí)行洗牌操作。這時,選擇題和填空都是隨機的,然后執(zhí)行列表.addAll(根列表)把申請問題放進去。這樣,在應(yīng)用題之前的填空題和選擇題都是隨機排列的,然后應(yīng)用題就排在最后