zoukankan      html  css  js  c++  java
  • 找水王

    要求:

      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);
        }
    }

    运行截图:

  • 相关阅读:
    day16(链表中倒数第k个结点)
    day15(C++格式化输出数字)
    day14(调整数组顺序使奇数位于偶数前面 )
    day13(数值的整数次)
    day12(二进制中1的个数)
    day11(矩形覆盖)
    day10(跳台阶)
    hadoop 又一次环境搭建
    Hive 学习
    hadoop -工具合集
  • 原文地址:https://www.cnblogs.com/zql-42/p/13084505.html
Copyright © 2011-2022 走看看