• 找水王


    题目要求

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

    解题思路

    因为“水王”发帖数目超过了帖子数目的一半,所以可以通过删帖的方式,两两比较id,相同则删一个,不同则都删了。最后剩下水王了。
    通过两两比较id,设置一个变量num为来记录当前id是否与下一个id相同。发言者如果id相同则为一个人num++,如果不相同则num--;

    代码

    public class FindWaterKing {
        public static void main(String[] args) {
            int[] id = {1,2,3,2,7,2,6,2,3,2,8,2,8,2,7,1,2};
            System.out.println("水王为:"+findTheWaterKing(id,id.length));
        }
    
        public static int findTheWaterKing(int[] id,int length){
            int waterKing = 0;
            int num = 0;
            for (int i=0;i<length;i++){
                if (num==0){
                    waterKing = id[i];
                    num++;
                }else if(waterKing==id[i]){
                    num++;
                }else if (waterKing!=id[i]){
                    num--;
                }
            }
            return waterKing;
        }
    }

  • 相关阅读:
    ubuntu下java环境变量配置
    批处理 控制 服务
    javascript break up a code line within a text string with a backslash.
    javascript for...in statement
    javascript output str to browser
    javascript RegExp
    javascript try catch throw
    javascript prototype
    javascript box
    java 移位处理
  • 原文地址:https://www.cnblogs.com/yeyueweiliang/p/13023308.html
Copyright © 2020-2023  润新知