给定 n 个整数,求里面出现次数最多的数,如果有多个重复出现的数,求值最大的那个 给定n个整数,求里面出现次数最多的数,如果有多个重复出现的数,求出值最大的一

简介: 给定 n 个整数,求里面出现次数最多的数,如果有多个重复出现的数,求值最大的那个 给定n个整数,求里面出现次数最多的数,如果有多个重复出现的数,求出值最大的一

题目描述:给定 n 个整数,求里面出现次数最多的数,如果有多个重复出现的数,求值最大的那个


输入格式


第一行输入一个整数n(1<n100000),接下来一行输入n个int 范围内的整数


输出格式


输出出现次数最多的数和出现的次数,中间用一个空格隔开,如果有多个重复出现的数,输出值最大的那个

代码实现:

import java.util.HashMap;
import java.util.Map;
import java.util.Scanner;
import java.util.*;
public class test16 {
        public static void main(String[] args) {
            Scanner scanner = new Scanner(System.in);
            //给定n的值
            int n = scanner.nextInt();
            List<Integer> intList = new ArrayList<>();
            //输入数据
            for (int i = 0; i < n; i++) {
                intList.add(scanner.nextInt());
            }
            // 使用 Map 来统计每个数的个数
            Map<Integer, Integer> numMap = new HashMap<>();
            for (int num : intList) {
                if (numMap.containsKey(num)) {
                    // 如果该数已经在map中存在,增加其计数
                    int count = numMap.get(num);
                    numMap.put(num, count + 1);
                } else {
                    // 如果该数不在map中,添加并设置计数为1
                    numMap.put(num, 1);
                }
            }
            Integer maxKey = null;
            Integer maxValue = null;
            for (Map.Entry<Integer, Integer> entry : numMap.entrySet()) {
                Integer key = entry.getKey();
                Integer value = entry.getValue();
                if (maxValue == null || value > maxValue) {
                    maxValue = value;
                    maxKey = key;
                }
            }
            System.out.println(maxKey+" "+maxValue);
        }
    }

输出如下所示:

5
1 1 2 3 4
1 2
相关文章
|
2月前
|
算法
给定两个数,求这两个数的最大公约数
给定两个数,求这两个数的最大公约数
|
4月前
|
Python
计算小于或等于n的非负整数区间包含的1的数量
计算小于或等于n的非负整数区间包含的1的数量
22 0
|
12月前
求整数序列中出现次数最多的数
求整数序列中出现次数最多的数
113 0
给定两个整数,M,N,表示区间【 2……n,2 m) ,请求出这个区间有多少个满足 i%7=1
给定两个整数,M,N,表示区间【 2……n,2 m) ,请求出这个区间有多少个满足 i%7=1
61 0
求出任意非负整数区间中1出现的次数
求出任意非负整数区间中1出现的次数
76 0
寻找重复数
给定一个包含 n + 1 个整数的数组 nums ,其数字都在 [1, n] 范围内(包括 1 和 n),可知至少存在一个重复的整数。 假设 nums 只有 一个重复的整数 ,返回 这个重复的数 。 你设计的解决方案必须 不修改 数组 nums 且只用常量级 O(1) 的额外空间
48 0
统计正数和负数的个数然后计算这些数的平均值(循环、数组解法)
统计正数和负数的个数然后计算这些数的平均值(循环、数组解法)
127 0