CCF201312-1:出现次数最多的数(JAVA版)

问题描述

  给定n个正整数,找出它们中出现次数最多的数。如果这样的数有多个,请输出其中最小的一个。

输入格式

  输入的第一行只有一个正整数n(1 ≤ n ≤ 1000),表示数字的个数。
  输入的第二行有n个整数s1, s2, …, sn (1 ≤ si ≤ 10000, 1 ≤ i ≤ n)。相邻的数用空格分隔。

输出格式

  输出这n个次数中出现次数最多的数。如果这样的数有多个,输出其中最小的一个。

样例输入

6
10 1 10 20 30 20

样例输出

10

 

先用一个list1存储每一个MyNumber对象,MyNumber对象包括数字和这个数字出现的次数,初始化的时候,都是出现1次,比如题目中给出的

6

10 1 10 20 30 20

在list1中的体现形式就是(10 1) (1 1) (10 1) (20 1) (30 1) (20 1)

经过遍历后的list             (10 2) (1 1) (10 1) (20 2) (30 1) (20 1)

定义一个方法getMaxValue(List list1) ,找到list1中次数出现最多的那个MyNumber

然后遍历list1,凡是出现次数等于获取到的maxValue的都放入list2中; 比如题目中的 (10 2)(20 2)被放入list2中

最后就是在list2中找到num最小的。得到(10 2) ,最后输出10

import java.util.ArrayList;
import java.util.List;
import java.util.Scanner;
public class Main {

	public static List list1 = new ArrayList();
	public static void main(String[] args) {
		
		Scanner sc = new Scanner(System.in);
		
		int n = sc.nextInt();
		
		//定义一个list 用于存储出现数字最多的数,如果这种数有多个就全放进去,一个就直接输出
		List list2 = new ArrayList();
		int x = 1;
		
		for(int i = 0;i list1) {
		int max = 0;
		for(int i = 0;imax){
				max = list1.get(i).count;
			}
		}
		return max;
	}
}

class MyNumber{
	int num ;//表示数字
	int count;//该数字出现的次数
	
	public MyNumber(int num,int count){
		this.num = num;
		this.count = count;
	}
	
	@Override
	public String toString() {
		
		return this.num +" "+ this.count;
	}
}

 

你可能感兴趣的:(CCF考试)