找水王

Posted kongfanbing

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了找水王相关的知识,希望对你有一定的参考价值。

要求:

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

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

设计思路:

 

  发帖者的id随机生成动态数组。水王发帖数量最多,最不怕消除,利用这点,消除相邻元素id不同的两个元素,最后剩下的就是“水王”。

代码:

技术图片
package test;
import java.util.Vector;


public class ShuiWang {

      public static void main(String[] args) {

        Vector<Integer> a=new Vector<>();//构建动态数组
        Integer s=6;
        for(int i=0;i<40;i++)
        {
            Integer k=(int) (1+Math.random()*100);
            a.add(k);//生成40个随机数
        }
        for(int i=0;i<60;i++)
        {
            a.insertElementAt(s,(int) (1+Math.random()*a.size()-1));//随机插入60个水王数字
        }
        for (Integer integer : a) System.out.print(integer + " ");
        System.out.println();
        int cnt=0;
        int ans=0;
        //解决思路为:不同的碰撞消失,相同的就增加数量
        for(int i=0;i<a.size();i++)
        {
            if(cnt==0)
            {
                ans=a.get(i);
                cnt++;
            }
            else
            {
                if(ans==a.get(i))
                    cnt++;
                else
                    cnt--;
            }
        }
        System.out.println();
        System.out.println("水王编号:"+ans);
    }
}
技术图片

运行截图:

技术图片

以上是关于找水王的主要内容,如果未能解决你的问题,请参考以下文章

找水王

找水王2

找水王续

课堂练习-找水王

找水王2

课堂练习--找水王