假如有10000个数,如何快速找到前20大的数字呢?
全部评论
先用前20的数构建一个小根堆,然后依次遍历后边的元素与堆顶元素比较,如果大于堆顶元素就替换堆顶元素,所有元素遍历完毕剩下小根堆的元素就算前20大的元素
37 回复 分享
发布于 2023-05-25 21:22 重庆
这道题可以有很多延伸:(1)简单的TopK算法 (2)大文件无法一次加载进内存如何找出TopK数字 (3)大文件找出频率次数最高的K个数字 (4)系统设计:Top-K Hitter找出一定时段内点击量最高的视频、博文
15 回复 分享
发布于 2023-05-26 09:38 山东
1w个数很小,所以怎么都可以
5 回复 分享
发布于 2023-05-25 23:34 广东
这不就是常问的 nth_element,或者快速选择。如果明确只有20,写20个 if else 也行
5 回复 分享
发布于 2023-05-25 21:25 上海
看我Arrays.sort( );一套for循环然后立马回家吃饭
3 回复 分享
发布于 2023-05-30 14:33 山东
复杂度o(2n),其实是极限求和n+n/2+...,求前k大都是这个复杂度,根本原因是不需要保证数据有序性
3 回复 分享
发布于 2023-05-26 09:23 山东
那么多数据 内存是否存的下?存的下那就小根堆 当然数值范围小直接桶排, 存不下就要分治。
点赞 回复 分享
发布于 2023-06-22 17:16 广西
介不大二作业吗
点赞 回复 分享
发布于 2023-06-20 18:04 江苏
一把sort排序梭哈
点赞 回复 分享
发布于 2023-06-19 10:56 甘肃
一眼堆,做过好几次了
点赞 回复 分享
发布于 2023-06-18 23:30 广东
直接放进map里面,从后往前输入20个
点赞 回复 分享
发布于 2023-06-09 08:37 广东
大数据可以用分治思想,分成n份分别做堆排,然后从中选最大的
点赞 回复 分享
发布于 2023-06-03 00:14 浙江
用小根堆时间复杂度比快排底,但是我自己实测是发现快排比堆快
点赞 回复 分享
发布于 2023-05-31 12:31 陕西
小根堆
点赞 回复 分享
发布于 2023-05-26 00:45 浙江
理论上不考虑资源,可以实现O1
点赞 回复 分享
发布于 2023-05-25 17:56 天津
小顶堆?
点赞 回复 分享
发布于 2023-05-25 15:50 广东

相关推荐

07-14 12:22
门头沟学院 Java
点赞 评论 收藏
分享
06-27 12:54
已编辑
门头沟学院 Java
累了,讲讲我的大学经历吧,目前在家待业。我是一个二本院校软件工程专业。最开始选专业是觉得计算机感兴趣,所以选择了他。本人学习计算机是从大二暑假结束开始的,也就是大三开始。当时每天学习,我个人认为Java以及是我生活的一部分了,就这样持续学习了一年半,来到了大四上学期末,大概是在12月中旬,我终于找的到了一家上海中厂的实习,但我发现实习生的工作很枯燥,公司分配的活也不多,大多时间也是自己在自学。就这样我秋招末才找到实习。时间来到了3月中旬,公司说我可以转正,但是转正工资只有7000,不过很稳定,不加班,双休,因为要回学校参加答辩了,同时当时也是心高气傲,认为可以找到更好的,所以放弃了转正机会,回学校准备论文。准备论文期间就也没有投递简历。然后时间来到了5月中旬,这时春招基本也结束了,然后我开始投递简历,期间只是约到了几家下场面试。工资也只有6-7k,到现在我不知道该怎么办了。已经没有当初学习的心劲了,好累呀,但是又不知道该干什么去。在家就是打游戏,boss简历投一投。每天日重一次。26秋招都说是针对26届的人,25怎么办。我好绝望。要不要参加考公、考研、央国企这些的。有没有大佬可以帮帮我。为什么感觉别人找工作都是顺其自然的事情,我感觉自己每一步都在艰难追赶。八股文背了又忘背了又忘,我每次都花很长时间去理解他,可是现在感觉八股、项目都忘完了。真的已经没有力气再去学习了。图片是我的简历,有没有大哥可以指正一下,或者说我应该走哪条路,有点不想在找工作了。
码客明:太累了就休息一下兄弟,人生不会完蛋的
如果实习可以转正,你会不...
点赞 评论 收藏
分享
评论
26
51
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务