首页 > 其他 > 详细

查找水王(课堂练习题)

时间:2020-05-26 23:36:58      阅读:37      评论:0      收藏:0      [点我收藏+]

一、题目要求

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

技术分享图片

查找水王(课堂练习题)

原文:https://www.cnblogs.com/yangxiao-/p/12968404.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!