zoukankan      html  css  js  c++  java
  • 课后作业之找水王

    题目是:

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

    大概思想是:

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

    (2)因为水王的id是最多的所以他最不怕删除,采用,相邻id相同保留一个,不相同全部删除。

    源代码:

    package com.find;
    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);
            }
            for(int i=0;i<53;i++)
            {
                a.insertElementAt(f,(int) (1+Math.random()*a.size()-1));
            }
            for (Integer integer : a) System.out.print(integer + " ");
            System.out.println();
            int cnt=0;
            int ans=0;
            // 相邻id相同保留一个,不相同全部删除。
            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);
        }
    }

    运行结果:

  • 相关阅读:
    Redis 是单进程单线程的?
    LeetCode-114. Flatten Binary Tree to Linked List
    Java HashMap源码分析
    转:zookeeper中Watcher和Notifications
    分布式服务框架
    LeetCode-330.Patching Array
    转:String StringBuffer StringBuilder区别
    最小堆代码实现
    数组的各类排序
    两步建立 ssh 反向隧道
  • 原文地址:https://www.cnblogs.com/w669399221/p/13068903.html
Copyright © 2011-2022 走看看