找水王

Posted xrj-

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了找水王相关的知识,希望对你有一定的参考价值。

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

方法:如果用户较少,可以采取先将ID排序,中间的就是水王,但这并不符合现实。正确做法是每次删两个不同ID的帖,最后就剩下了水王。

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

}





以上是关于找水王的主要内容,如果未能解决你的问题,请参考以下文章

找水王

找水王2

找水王续

课堂练习-找水王

找水王2

课堂练习--找水王