• 找水王


    一、题目要求

    三人行设计了一个灌水论坛。信息学院的学生都喜欢在上面交流灌水,传说在论坛上有一个“水王”,他不但喜欢发帖,还会回复其他ID发的每个帖子。坊间风闻该“水王”发帖数目超过了帖子数目的一半。 如果你有一张当前论坛的帖子(包括回帖)列表,其中帖子的作者的ID也在其中,你能快速的找到这个传说中的水王吗?

    二、设计思想

    (1)发帖者的id随机生成动态数组。

    (2)利用“消消乐”的思想,消除相邻元素id不同的两个元素,最后剩下的便是“水王”。

    (3)输出结果

    三、代码实现

    package shuiwang;
    
    import java.util.Vector;
    /*
    找出水王
     */
    
    public class Main {
    
        public static void main(String[] args) {
            Vector<Integer> a=new Vector<>();//构建动态数组
            Integer f=8;
            for(int i=0;i<47;i++)
            {
                Integer k=(int) (1+Math.random()*100);
                a.add(k);//添加48个在1-100的随机数
            }
            for(int i=0;i<53;i++)
            {
                a.insertElementAt(f,(int) (1+Math.random()*a.size()-1));//向这48个数中随机插入8,这个水王数字
            }
            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);
        }
    }
    Main.java

    四、运行截图

  • 相关阅读:
    Linux下 Nginx 启动 重启 关闭
    在Idea中 的terminal 使用 git
    前端页面出现乱码
    Mac下Eclipse(Oxygen)添加Tomcat插件
    Linux下vsftp匿名用户配置
    500 OOPS: vsftpd: refusing to run with writable anonymous root
    FTP数字代码的意义
    CentOS 6.3下安装Vsftp,虚拟用户
    CentOS 6.3 下 vsftp搭建
    CentOS 6.3安装配置LAMP服务器(Linux+Apache+MySQL+PHP5)
  • 原文地址:https://www.cnblogs.com/MoooJL/p/12976646.html
Copyright © 2020-2023  润新知