23 最大N个数与最小N个数的和

题目描述

给定一个数组,编写一个函数来计算它的最大N个数与最小N个数的和。你需要对数组进行去重。说明:

·数组中数字范围[0,1000]

·最大N个数与最小N个数不能有重叠,如有重叠,输入非法返回-1·输入非法返回-1

输入描述

·第一行输入M,M标识数组大小·第二行输入M个数,标识数组内容

·第三行输入N,N表达需要计算的最大、最小N个数

输出描述

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

用例

5

输入 95 88 83 64 100

2

输出 342

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

5

输入 32342

2

输出 -1

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

复制代码
import java.util.Arrays;
import java.util.HashSet;
import java.util.Scanner;
 
public class Main {
  public static void main(String[] args) {
    Scanner sc = new Scanner(System.in);
 
    int m = sc.nextInt();
 
    int[] arr = new int[m];
    for (int i = 0; i < m; i++) {
      arr[i] = sc.nextInt();
    }
 
    int n = sc.nextInt();
 
    System.out.println(getResult(m, arr, n));
  }
 
  public static int getResult(int m, int[] arr, int n) {
    HashSet<Integer> set = new HashSet<>();
 
    for (int val : arr) {
      if (val < 0 || val > 1000) return -1;
      set.add(val);
    }
 
    if (set.size() < n * 2) return -1;
 
    Integer[] distinct_arr = set.toArray(new Integer[0]);
 
    Arrays.sort(distinct_arr, (a, b) -> a - b);
 
    int l = 0;
    int r = distinct_arr.length - 1;
    int ans = 0;
 
    while (n > 0) {
      ans += distinct_arr[l] + distinct_arr[r];
      l++;
      r--;
      n--;
    }
 
    return ans;
  }
}
相关推荐
W23035765735 小时前
经典算法:最长上升子序列(LIS)深度解析 C++ 实现
开发语言·c++·算法
2401_892070985 小时前
链栈(链式栈) 超详细实现(C 语言 + 逐行精讲)
c语言·数据结构·链栈
minji...6 小时前
Linux 线程同步与互斥(三) 生产者消费者模型,基于阻塞队列的生产者消费者模型的代码实现
linux·运维·服务器·开发语言·网络·c++·算法
语戚7 小时前
力扣 968. 监控二叉树 —— 贪心 & 树形 DP 双解法递归 + 非递归全解(Java 实现)
java·算法·leetcode·贪心算法·动态规划·力扣·
skywalker_117 小时前
力扣hot100-7(接雨水),8(无重复字符的最长子串)
算法·leetcode·职场和发展
bIo7lyA8v8 小时前
算法稳定性分析中的输入扰动建模的技术9
算法
CoderCodingNo8 小时前
【GESP】C++三级真题 luogu-B4499, [GESP202603 三级] 二进制回文串
数据结构·c++·算法
sinat_286945198 小时前
AI Coding 时代的 TDD:从理念到工程落地
人工智能·深度学习·算法·tdd
炽烈小老头8 小时前
【 每天学习一点算法 2026/04/12】x 的平方根
学习·算法