Top K问题详解

一、Top K问题的概述

       在大规模数据处理中,经常会遇到的一类问题:在海量数据中找出出现频率最好的前k个数,或者从海量数据中找出最大的前k个数,这类问题通常被称为top K问题。例如在搜索引擎中,统计搜索最热门的10个查询词;在歌曲库中统计下载最高的前10首歌等。针对top K类问题通常比较好的方案是分治+Trie树/hash+小顶堆,即先将数据集按照Hash方法分解成多个小数据集,然后使用Trie树或者Hash统计每个小数据集中的query词频,之后用小顶堆求出每个数据集中出现频率最高的前K个数,最后在所有top K中求出最终的top K。eg:有1亿个浮点数,如果找出期中最大的10000个?

二、常规思维

       最容易想到的方法是将数据全部排序,然后在排序后的集合中进行查找,最快的排序算法的时间复杂度一般为O(nlogn),如快速排序。但是在32位的机器上,每个float类型占4个字节,1亿个浮点数就要占用400MB的存储空间,对于一些可用内存小于400M的计算机而言,很显然是不能一次将全部数据读入内存进行排序的。其实即使内存能够满足要求该方法也并不高效,因为题目的目的是寻找出最大的10000个数即可,而排序却是将所有的元素都排序了,做了很多的无用功。

三、局部淘汰法

       局部淘汰法与排序方法类似,用一个容器保存前10000个数,然后将剩余的所有数字——与容器内的最小数字相比,如果所有后续的元素都比容器内的10000个数还小,那么容器内这个10000个数就是最大10000个数。如果某一后续元素比容器内最小数字大,则删掉容器内最小元素,并将该元素插入容器

  • 1
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
top命令是Linux下的一个常用命令,用于查看系统的性能状况,包括CPU、内存、进程等信息。下面是top命令用法的详细介绍: 1. 命令格式 top命令的基本格式为: ``` top [options] ``` 2. 命令参数 top命令的常用参数如下: - -d seconds:指定top命令的刷新时间,默认为3秒。 - -n iterations:指定top命令的刷新次数,执行完后自动退出。 - -p pid:显示指定进程的信息。 - -U username:显示指定用户的信息。 - -u username:显示指定用户或进程的信息。 - -b:以批处理模式运行,输出到文件。 - -c:显示完整的命令行信息。 - -i:不显示闲置的进程。 - -o field:按照指定的字段排序,可以用逗号分隔多个字段。 - -h:显示帮助信息。 3. 显示内容 top命令默认显示的内容包括: - 第一行:系统启动时间、系统运行时间、当前登录用户数、负载平均值。 - 第二行:总进程数、运行中的进程数、休眠进程数、停止进程数、僵尸进程数。 - 第三行:CPU的使用情况,包括用户进程、系统进程、空闲进程、等待输入/输出的进程、硬中断和软中断。 - 后面的行:按照CPU使用率从高到低排列的进程列表,包括进程ID、用户名、CPU使用率、内存使用率、进程状态、运行时间、命令行。 4. 常用操作 - h:显示帮助信息。 - q:退出top命令。 - k:结束指定进程。 - r:修改进程的优先级。 - s:修改top命令的刷新时间。 - Space:刷新top命令的显示内容。 总之,top命令是Linux系统监控和调试的重要工具之一,掌握其用法可以更好地了解系统的性能状况,提高系统的稳定性和可靠性。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

抽离的心

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值