题目:

 

 

程序设计思想:

  在开始思考之前,应当仔细把题目读过一遍,尽量捕捉有用的信息,找出点睛之笔。

  就这个题目而言,要找出水王,最重要的信息就是:“水王”发帖数目超过了帖子数目的一半!!!而且目前我们有一张当前论坛的帖子(包括回帖)列表。

  在此假设我们用数组历来存储帖子列表,那也就说明,如果我们从帖子头部开始顺次往下,相同id的帖子将其id所在数组下标记录,并将其id出现次数记录(记录在案的是可能的水王的信息)——注意,这里我们每次找到。若出现两个帖子的id不一致,则将这两个id都删除掉,就是说将记录在案的id的次数减1,另一个不一致的id则跳过不理会。依次往下在到达帖子列表尾部之前,若出现记录的id的次数减为0的情况,则说明当前记录的id并非水王。

  此时应当从检索到的id的下一个id开始重复以上步骤,直到遇到检索到帖子结尾还没有减为0的ID即为水王id。

 

  源代码:

  

import java.util.Scanner;
/*
 * 寻找水王
 */
public class WaterKing {
    public static void main(String[] args) {
        int[] a = null;//存储帖子id
                Scanner sc = new Scanner(System.in);
        System.out.println("帖子总个数:");
        int sum = sc.nextInt();
        a = new int[sum];
        System.out.println("输入每个帖子的作者:");
        for(int i = 0;i < sum;i++)
        {
            a[i] = sc.nextInt();
        }
        sc.close();
        int n = 0;
        int nid = -1;

        for(int i = 0;i < a.length - 1;i++)
        {
            if(n == 0)
            {
                if(a[i] == a[i + 1])
                {
                    n = 2;
                    nid = a[i];
                }
                else
                {
                    i++;
                    if((i + 1) == a.length - 1)
                    {
                        nid = a[a.length - 1];
                    }
                }
            }
            else
            {
                if(nid == a[i])
                {
                    n++;
                }
                else
                {
                    n--;
                }
            }
        }
        System.out.println("水王的ID : " + nid);
        
    }

    
}