华为OD机试C卷-- 最大N个数与最小N个数的和(Java & JS & Python)

2024-06-01 1442阅读

获取题库不需要订阅专栏,可直接私信我进入CSDN领军人物top1博主的华为OD交流圈观看完整题库、最新面试实况、考试报告等内容以及大佬一对一答疑。
题目描述
给定一个数组,编写一个函数来计算它的最大N个数与最小N个数的和。你需要对数组进行去重。

华为OD机试C卷-- 最大N个数与最小N个数的和(Java & JS & Python)
(图片来源网络,侵删)

说明:

  • 数组中数字范围[0, 1000]
  • 最大N个数与最小N个数不能有重叠,如有重叠,输入非法返回-1
  • 输入非法返回-1

输入描述

  • 第一行输入M, M标识数组大小
  • 第二行输入M个数,标识数组内容
  • 第三行输入N,N表达需要计算的最大、最小N个数

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

题目解析
题目要求给定一个数组,计算并返回数组中不重复的最大N个数与最小N个数的和。首先,我们需要对数组进行去重,然后分别找到数组中的最大N个数和最小N个数。需要注意的是,这两个集合不能有重叠,如果有重叠则输入非法,返回-1。

算法步骤
1.读取数组大小和数组内容。
2.读取需要计算的最大、最小N个数。
3.对数组进行去重。
4.找出去重后数组中的最大N个数和最小N个数(这里我们使用优先队列(最小堆和最大堆)来分别存储最大和最小的N个数)。
5.检查这两个集合是否有重叠。
6.如果没有重叠,计算并返回它们的和;如果有重叠或输入非法,则返回-1。

Java算法源码

VPS购买请点击我

免责声明:我们致力于保护作者版权,注重分享,被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理! 图片声明:本站部分配图来自人工智能系统AI生成,觅知网授权图片,PxHere摄影无版权图库和百度,360,搜狗等多加搜索引擎自动关键词搜索配图,如有侵权的图片,请第一时间联系我们,邮箱:ciyunidc@ciyunshuju.com。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!

目录[+]