《编程之美》 2.3 寻找发帖的“水王”
来源:互联网 发布:东方红资产管理 知乎 编辑:程序博客网 时间:2024/06/05 14:20
问题描述:
Tango 是微软亚洲研究院的一个实验项目,研究院的员工和实习生们都很喜欢在Tango上面交流灌水。传说,Tango有一大“水王”,他不但喜欢发帖,还会回复其他ID发的每个帖子。坊间风闻该“水王”发帖数目超过了帖子总数的一半。如果你有一个当前论坛上所有帖子(包括回帖)的列表,其中帖子作者的ID也在表中,你能快速找出这个传说中的Tango水王吗?
分析:
如果对ID列表排序然后再寻找,存在排序的时间复杂度,如何避免排序呢?
如果每次删除两个不同的ID(不管是否包含”水王“的ID),那么,在剩下的ID列表中,”水王“ID出现的次数仍然超过总数的一半。可以通过不断重复这个过程,把ID列表的ID总数降低(转化为更小的问题),从而得到答案。新的思路,避免了排序这个耗时的步骤,总的时间复杂度只有O(N),且只需要常数的额外内存。
伪代码如下:
Type Find(Type* ID,int N){Type candidate;int nTimes,i;for(i = nTimes = 0;i < N;i++){if(nTimes == 0){candidate = ID[i],nTimes = 1;}else{if(candidate == ID[i])nTimes++;elsenTimes--;}}return candidate;
- 编程之美2.3 寻找发帖“水王”
- 编程之美-2.3-寻找发帖“水王”
- 编程之美-2.3-寻找发帖“水王”
- 编程之美 2.3 寻找发帖“水王”
- 编程之美2.3 寻找发帖“水王”
- 编程之美2.3 寻找发帖"水王"
- 编程之美 2.3 寻找发帖“水王”
- 编程之美2.3寻找发帖"水王"
- 编程之美2.3 寻找发帖“水王”
- 《编程之美》 2.3 寻找发帖的“水王”
- 编程之美-寻找发帖"水王"
- 寻找发帖“水王”--《编程之美》笔记
- 寻找发帖“水王”--《编程之美》笔记
- 编程之美 寻找发帖“水王”
- 编程之美-寻找发帖“水王”
- 编程之美---寻找发帖“水王”
- 读书笔记之编程之美 - 2.3 寻找发帖“水王”
- 《编程之美》之读书笔记 2.3寻找发帖“水王”
- DAO数据库:查询
- 网络与通讯程序设计CIOCPServer类
- BSS段,数据段,代码段,堆,栈简单介绍
- Ext.Ajax.request发送同步请求---基于ext-basex
- Ajax无刷新提交表单实例
- 《编程之美》 2.3 寻找发帖的“水王”
- Ext.Ajax.request 与formPanel.getForm().submit()
- DAO查询
- location.href 在Firefox下的替代方案
- Javascript的IE和Firefox兼容性汇编
- 做一个与bug共存的程序员
- Oracle Fusion Applications : Frequently Asked Questions
- IRP(I/O Request Package)详解
- QWS Server