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

一、题目

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

二、设计思路

  参考原来问题的解法,如果每次删除4个不同的ID(不管是否超过总数1/4的ID),那么,剩下的ID列表中,原先发帖比例大于1/4的ID所占比例仍然大于1/4。可以通过不断重复这个过程,把ID总数降低,从而得到问题的答案。具体方法:用candidate[3]记录三个候选ID,用count[3]记录它们的累积次数,然后遍历整个ID列表,每处理一个ID,若与candidate[i]中的某一个相同,则count[i]++,若与三个都不同,则说明找到了四个互不相同的ID,将三个count[i]--,也就相当于“删除了四个不同ID”,若某一个count[i]==0,则更新之。

三、源代码

 1 package com.java.lianxi;
 2
 3 public class lianxi8 {
 4     public static void main(String arg[]){
 5         int ID[]={1,2,1,1,2,3,2,3,3,4,4};
 6         Find(ID);
 7     }
 8     public static void Find(int ID[])
 9     {
10         int i,N=ID.length;
11         int nTimes[]=new int[3];
12         int candidate[]=new int[3];
13         nTimes[0]=nTimes[1]=nTimes[2]=0;
14         candidate[0]=candidate[1]=candidate[2]=0;
15         for(i = 0; i < N; i++)
16         {
17             if(ID[i]==candidate[0])
18             {
19                  nTimes[0]++;
20             }
21             else if(ID[i]==candidate[1])
22             {
23                  nTimes[1]++;
24             }
25             else if(ID[i]==candidate[2])
26             {
27                  nTimes[2]++;
28             }
29             else if(nTimes[0]==0)
30             {
31                  nTimes[0]=1;
32                  candidate[0]=ID[i];
33             }
34             else if(nTimes[1]==0)
35             {
36                  nTimes[1]=1;
37                  candidate[1]=ID[i];
38             }
39             else if(nTimes[2]==0)
40             {
41                  nTimes[2]=1;
42                  candidate[2]=ID[i];
43             }
44             else
45             {
46                  nTimes[0]--;
47                  nTimes[1]--;
48                  nTimes[2]--;
49              }
50         }
51         for(i=0;i<3;i++)
52         {
53             System.out.println("水王"+(i+1)+"的ID是"+candidate[i]);
54         }
55         }
56
57 }

四、截图

五、实验总结

  这次找水王的扩展,和原来找水王的思路是一样的,都是采用互消的方法,只不过由两两互消变为了四个四个的消。我们以后解决这种扩展问题时,一定要站在原来问题的基础上思考,这样思路就会更加清晰,解决问题的效率会更高。

时间: 2024-10-10 18:31:32

软件工程——找水王(续)的相关文章

找水王(二)

一.题目 一段时间之后,大水王消失了,出现了三个小水王,他们每一个人发帖数超过了总数的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看成一位数组,简化 为,在一位数组中,查找一半以上相同的元素

课堂练习—找水王(续)

一.题目 随着论坛的发展,管理员发现水王没有了,但是统计结果表明,有三个发帖很多的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,你能从发帖列表中快速找到他们吗? 二.设计思想 给

软件工程概论---找水王问题

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

找水王问题续

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