华为od(D卷)最大N个数和最小N个数的和

文章目录

题目描述

给定一个数组,编写一个函数,来计算他的最大N个数和最小N个数的和,需要对数组进行去重

输入描述

第一行输入M,M表示数组大小

第二行输入M个数,表示数组内容

第三行输入N表示需要计算的最大最小N的个数

输出描述

输出最大N个数和最小N个数的和

示例1

输入

5

95 88 83 64 100

2
输出

342
说明:最大2个数[100 95] 最小2个数[83 64],输出342

示例2

输入

5

3 2 3 4 2

2
输出

-1

说明:最大两个数是[4 3]最小2个数是[3 2],有重叠输出为-1

思路

去重 : 利用set
最大,最小 : 排序。

排序+去重:TreeSet

代码

复制代码
public class Demo02 {
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        while (in.hasNextInt()) {
            TreeSet<Integer> treeSet = new TreeSet<>();
            int m = in.nextInt();
            for (int i = 0; i < m; i++) {
                treeSet.add(in.nextInt());
            }
            int n = in.nextInt();

            if (treeSet.size() < 2 * n) {
                System.out.println(-1);
                return;
            }
            int sum = 0;

            for (int i = 0; i < n; i++) {
                sum += treeSet.first();
                treeSet.remove(treeSet.first());
                sum += treeSet.last();
                treeSet.remove(treeSet.last());
            }
            System.out.println(sum);
        }

        in.close();
    }
}
相关推荐
坠金9 小时前
递归、递归和回溯的区别
算法
zhougl9969 小时前
Java 枚举类(enum)详解
java·开发语言·python
想七想八不如114089 小时前
2019机试真题
java·华为od·华为
恋爱绝缘体19 小时前
Java语言提供了八种基本类型。六种数字类型【函数基数噶】
java·python·算法
仰泳的熊猫9 小时前
题目1434:蓝桥杯历届试题-回文数字
数据结构·c++·算法·蓝桥杯
星火开发设计9 小时前
格式化输入输出:控制输出精度与对齐方式
开发语言·c++·学习·算法·函数·知识
ygklwyf10 小时前
模拟退火算法零基础快速入门
数据结构·c++·算法·模拟退火算法
XX風10 小时前
3.3 GMM (高斯混合模型)
人工智能·算法·机器学习
MX_935910 小时前
使用Spring的BeanFactoryPostProcessor扩展点完成自定义注解扫描
java·后端·spring
弹简特10 小时前
【JavaEE05-后端部分】使用idea社区版从零开始创建第一个 SpringBoot 程序
java·spring boot·后端