蓝桥杯试题:排序

一、题目大意

输入一个数字n(n<=1e5),然后输入一个长度为n的数组 an(-1e9<=ai<=1e9)

请你输出出现频率最大的数,如果有多个数频率最大,按从小到大依次输出。

示例1:

输入5 1 1 2 2 0

输出 1 2

示例2:

输入9 0 0 -1 -1 2 2 5 5 7

输出 -1 0 2 5

二、代码展示

java 复制代码
import java.util.*;
import java.util.Map.Entry;

public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        Map<Integer , Integer>map = new HashMap<>(); //MAP储存每个数出现的次数
        for (int i = 0; i < n; i++) {
            int a = sc.nextInt();
            map.put(a,map.getOrDefault(a,0)+1);
        }

        int max = 0;
        for (Entry <Integer , Integer> entry:map.entrySet()) {
            max = Math.max(max , entry.getValue());
        }

        List<Integer>list = new ArrayList<>();  //出现次数最大的值都放在list中
        for (Entry<Integer , Integer>entry:map.entrySet()){
            if (entry.getValue() == max){
                list.add(entry.getKey());
            }
        }
        Collections.sort(list); //list排序
        for (int x:list){
            System.out.print(x + " ");
        }

    }
相关推荐
一个不知名程序员www18 分钟前
算法学习入门---前缀和(C++)
c++·算法
jackzhuoa31 分钟前
Rust API 设计的零成本抽象原则:从语言基石到工程实践
算法·rust
我不是彭于晏丶1 小时前
238. 除自身以外数组的乘积
数据结构·算法
兮山与1 小时前
算法25.0
算法
爱编程的鱼1 小时前
想学编程作为今后的工作技能,学哪种语言适用性更强?
开发语言·算法·c#·bug
yq14682860902 小时前
C (统计二进制中“1“的个数)
c语言·开发语言·算法
被AI抢饭碗的人2 小时前
算法题(254):灾后重建
算法·leetcode·职场和发展
深度学习机器2 小时前
RAG的另一种思路,基于文档树结构的推理型检索
人工智能·算法·架构
深度学习机器2 小时前
Agent架构新方向?Claude Skills工作原理解析
人工智能·算法·架构
蓝色汪洋2 小时前
最近联系人-有点疑惑
算法