> 文章列表 > 【华为OD机试真题 C++】1074 - 最大N个数与最小N个数的和 | 机试题+算法思路+考点+代码解析

【华为OD机试真题 C++】1074 - 最大N个数与最小N个数的和 | 机试题+算法思路+考点+代码解析

【华为OD机试真题 C++】1074 - 最大N个数与最小N个数的和 | 机试题+算法思路+考点+代码解析

文章目录

    • 一、题目
      • 🔸题目描述
      • 🔸输入输出
      • 🔸样例1
      • 🔸样例2
    • 二、代码参考
  • 作者:KJ.JK

🌈 🌈 🌈 🌈 🌈 🌈 🌈 🌈 🌈 🌈 🌈 🌈 🌈
 
🍂个人博客首页: KJ.JK
 
💖系列专栏:华为OD机试真题(C++)


一、题目


🔸题目描述

给定一个数组,编写一个函数来计算它的最大N个数最小N个数的和。你需要对数组进行去重。
说明:
1、数组中数字范围[0, 1000]
2、最大N个数与最小N个数不能有重叠,如有 ** 重叠,输入非法 **返回-1
3、输入非法返回-1


🔸输入输出

输入
第一行输入M,M表示数组大小
第二行输入M个数,表示数组内容
第三行输入N, 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说明:
最大2个数[4,3],最小2个数[3,2],有重叠输出为-1

二、代码参考

#include <iostream>
#include <algorithm>
#include <unordered_set>
using namespace std;int getSumOfMaxAndMinN(int size, int nums[], int n) {unordered_set<int> numSet;  // 使用无序集合去重// 将数组中的数字插入到集合中,同时判断数字是否符合要求for (int i = 0; i < size; i++) {if (nums[i] < 0 || nums[i] > 1000) return -1;  // 不符合要求,返回-1numSet.insert(nums[i]);}if (numSet.size() < n * 2) return -1;  // 数组中不足2n个不同的数字,返回-1int distinctNums[numSet.size()];  // 存储去重后的数字int index = 0;for (auto val : numSet) {distinctNums[index++] = val;}sort(distinctNums, distinctNums + numSet.size());  // 排序int left = 0;int right = numSet.size() - 1;int sum = 0;while (n > 0) {sum += distinctNums[left] + distinctNums[right];  // 计算最大和最小n个数字之和left++;right--;n--;}return sum;
}int main() {int size;cin >> size;int nums[size];for (int i = 0; i < size; i++) {cin >> nums[i];}int n;cin >> n;cout << getSumOfMaxAndMinN(size, nums, n) << endl;return 0;
}

作者:KJ.JK

文章对你有所帮助的话,欢迎给个赞或者 star,你的支持是对作者最大的鼓励,不足之处可以在评论区多多指正,交流学习