软件工程课堂十(找水王)
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); } }