代码改变世界

软件工程课堂十(找水王)

2019-06-02 20:48  一念永恒s  阅读(257)  评论(0编辑  收藏  举报

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

设计思路:通过对每个存入数组的数据进行挨个遍历,然后输出查找到的最多的次数的id,即是水王。以下是部分代码:

package practice;
import java.util.Scanner;
public class practice {
        public static void main(String[] args) {
            int[] a = null;//存储
            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);
        }
    }