找水王问题续

一、题目

三人行设计了一个灌水论坛。信息学院的学生都喜欢在上面交流灌水,传说在论坛上有一个“水王”,他不但喜欢发帖,还会回复其他ID发的每个帖子。坊间风闻该“水王”发帖数目超过了帖子数目的一半。

如果你有一张当前论坛的帖子(包括回帖)列表,其中帖子的作者的ID也在其中,你能快速的找到这个传说中的水王吗?

随着论坛的发展,管理员发现水王没有了,但是统计结果表明,有三个发帖很多的ID。据统计他们的发帖数量超过了1/4,你能从发帖列表中快速找到他们吗?

二、设计思想

延续上一篇找发帖数超过一半的ID的思想,将不同的消去。这次是将三个ID放入一个数组,与其他ID比较,不同则消去,最后剩下的就是最多的三个ID。设置数组k计数来实现消去。

三、代码

 1 #include <iostream.h>
 2
 3 int main()
 4 {
 5     int n[20]={1,2,8,9,7,1,1,6,1,2,2,9,11,15,2,1,2,1,9,9};
 6     int tienum=20;
 7     int i,j;
 8     int shui[3]={0,0,0},k[3]={0,0,0};
 9
10     for(i=1;i<tienum;i++)
11     {
12
13         if (shui[0]==n[i])
14             k[0]++;
15         else if (shui[1]==n[i])
16             k[1]++;
17         else if (shui[2]==n[i])
18             k[2]++;
19         else if (k[0]==0)
20         {
21             shui[0]=n[i];
22             k[0]++;
23         }
24         else if (k[1]==0)
25         {
26             shui[1]=n[i];
27             k[1]++;
28         }
29         else if (k[2]==0)
30         {
31             shui[2]=n[i];
32             k[2]++;
33         }
34         else
35         {
36             k[0]--;
37             k[1]--;
38             k[2]--;
39         }
40     }
41     cout<<"水王ID是:"<<shui[0]<<"和"<<shui[1]<<"和"<<shui[2]<<endl;
42     return 0;
43 }

四、实验结果截图

五、总结

这是上一次题目的扩展,关键的消除思想已经有了,这次主要是解决三个ID的比较消去方法,即如何实现计数。通过同学讨论和参考核心代码实现。同时这次仍是对优化算法的训练,这些优化训练拓展了我们的思路。

时间: 2024-10-14 01:08:55

找水王问题续的相关文章

软件工程——找水王(续)

一.题目 随着论坛的发展,管理员发现水王没有了,但是统计结果表明,有三个发帖很多的ID.据统计他们的发帖数量超过了1/4,你能从发帖列表中快速找到他们吗 二.设计思路 参考原来问题的解法,如果每次删除4个不同的ID(不管是否超过总数1/4的ID),那么,剩下的ID列表中,原先发帖比例大于1/4的ID所占比例仍然大于1/4.可以通过不断重复这个过程,把ID总数降低,从而得到问题的答案.具体方法:用candidate[3]记录三个候选ID,用count[3]记录它们的累积次数,然后遍历整个ID列表,

课堂练习—找水王(续)

一.题目 随着论坛的发展,管理员发现水王没有了,但是统计结果表明,有三个发帖很多的ID.据统计他们的发帖数量超过了1/4,你能从发帖列表中快速找到他们吗 二.设计思路 上次是每次删除两个ID,即如果两个ID不同则删除,相同则保留,这次参考原来问题的解法,如果按照数序删除四个完全不同的ID,那么,最后剩下的就是原先发帖比例大于1/4的ID.循环这个过程,把ID总数降低,从而得到问题的答案. 三.源代码 #include<iostream.h> int main() { int ID[10]={1

找水王(续)

一.题目: 1 三人行设计了一个灌水论坛.信息学院的学生都喜欢在上面交流灌水,传说在论坛上有一个“水王”,他不但喜欢发帖,还会回复其他ID发的每个帖子.坊间风闻该“水王”发帖数 目超过了帖子数目的一半. 2 如果你有一张当前论坛的帖子(包括回帖)列表,其中帖子的作者的ID也在其中,你能快速的找到这个传说中的水王吗?(参考核心代码) 3 随着论坛的发展,管理员发现水王没有了,但是统计结果表明,有三个发帖很多的ID.据统计他们的发帖数量超过了1/4,你能从发帖列表中快速找到他们吗? 二.设计思想 给

水贴王之续,找出数组里出现频率最高的元素

找出数组里出现频率最高的元素 个人信息:就读于燕大本科软件工程专业 目前大三; 本人博客:google搜索"cqs_2012"即可; 个人爱好:酷爱数据结构和算法,希望将来从事算法工作为人民作出自己的贡献; 博客内容:水贴王问题之续 博客时间:2014-5-12; 编程语言:Java ; 编程坏境:Windows 7 专业版 x64; 编程工具:jdk,eclipse x64; 制图工具:office 2007 powerpoint; 硬件信息:7G-3 笔记本; 真言: 痛苦的活着比

找水王(二)

一.题目 一段时间之后,大水王消失了,出现了三个小水王,他们每一个人发帖数超过了总数的1/4. 要求:如果你有一张当前论坛的帖子(包括回帖)列表,其中帖子的作者的ID也在其中,你能快速的找到这三个小水王吗? 二.解题思路 将第一次找水王的套路扩展一下,每次删除四个不同的结点,最后就能得到三只水王 三.程序代码 1 #include<iostream> 2 #include<string> 3 using namespace std; 4 int main() 5 { 6 //建立数

找水王 多个水王

package Arraysum; public class FindWaterKing { public static void main(String[] args) { //把id列表放到一个数组里面 int[] idNum = {1,1,1,1,12,3,11,1,1,15,6,6,77,1,1,1,1}; //指向前一个数和后一个数的指针 int previor = 0; int next = 1; //通过while循环来实现两两相消法 while((previor < idNum.

课堂练习—找水王之小水王

三人行设计了一个灌水论坛.信息学院的学生都喜欢在上面交流灌水,传说在论坛上有一个“水王”,他不但喜欢发帖,还会回复其他ID发的每个帖子.坊间风闻该“水王”发帖数目超过了帖子数目的一半. 要求:如果你有一张当前论坛的帖子(包括回帖)列表,其中帖子的作者的ID也在其中,你能快速的找到这个传说中的水王吗? 解决方法: 对所面临的问题进行简化,由于“水王”发帖数目超过了帖子数目的一半,由此可以作为突破口,寻找简单的方法,来解决,可以将发帖的ID看成一位数组,简化 为,在一位数组中,查找一半以上相同的元素

找水王课堂练习

1题目要求: 三人行设计了一个灌水论坛.信息学院的学生都喜欢在上面交流灌水,传说在论坛上有一个“水王”,他不但喜欢发帖,还会回复其他ID发的每个帖子.坊间风闻该“水王”发帖数目超过了帖子数目的一半. 如果你有一张当前论坛的帖子(包括回帖)列表,其中帖子的作者的ID也在其中,你能快速的找到这个传说中的水王吗? 2 设计思路: 1首先如果每次删除两个不同的ID,那么,在剩下的ID列表中,“水王”ID出现的次数仍然超过总数的一半. 2重复这个过程,把ID列表中的ID总数降低,最后找到水王. 3源程序代

找水王问题

1.题目: 三人行设计了一个灌水论坛.信息学院的学生都喜欢在上面交流灌水,传说在论坛上有一个“水王”,他不但喜欢发帖,还会回复其他ID发的每个帖子.坊间风闻该“水王”发帖数目超过了帖子数目的一半. 如果你有一张当前论坛的帖子(包括回帖)列表,其中帖子的作者的ID也在其中,你能快速的找到这个传说中的水王吗? 2.设计思路: 采用消消乐的逆向思想,把相邻的两个不同id依次消掉,由于水王id多于总数的一半,所以最终剩下的一定是水王id. 3.源代码: 1 #include <iostream.h>