华为OD机考算法题:阿里巴巴找黄金宝箱(V)

2023-10-30 14:20

本文主要是介绍华为OD机考算法题:阿里巴巴找黄金宝箱(V),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目部分

题目阿里巴巴找黄金宝箱(V)
难度
题目说明一贫如洗的樵夫阿里巴巴在去砍柴的路上,无意中发现了强盗集团的藏宝地,藏宝地有编号从0-N的箱子,每个箱子上面贴有一个数字。
阿里巴巴念出一个咒语数字 k ( k<N ),找出连续 k 个宝箱数字和的最大值,并输出该最大值。
输入描述第一行输入一个数字字串,数字之间使用逗号分隔,例如: 2,10,-3,-8,40,5。
1 ≤ 字串中数字的个数 ≤ 100000。

-10000 ≤ 每个数字 ≤10000。
第二行输入咒语数字,例如: 4,咒语数字大小小于宝箱的个数。
输出描述连续 k 个宝箱数字和的最大值,例如: 39。
补充说明
------------------------------------------------------
示例
示例1
输入2,10,-3,-8,40,5
输出39
说明
示例2
输入8
1
输出8
说明


解读与分析

题目解读

给出 N 个数字,求出这 N 个数字中连续 k (k ≤ N)个数字之和的最大值。

分析与思路

设数字放到数组 numArr 中从第 1 个元素 numArr[0] 开始,求出连续 k 个数字(numArr[0]、numArr[1] …… numArr[ k - 1])之和,记录下来,设为 tmpSum。设连续 k 个数字之和最大值为 maxSum,初始复制为 maxSum = tmpSum。然后,向右滑动数字块一位,在 即 tmpSum - numArr[0] + numArr[ k ],如果它大于 maxSum,则给 maxSum 赋新值,直至遍历完所有的数字。

此方法只需要遍历一次数组,时间复杂度为 O(n),空间复杂度为 O(1)。


代码实现

Java代码

import java.util.Scanner;/*** 阿里巴巴黄金宝箱* * @since 2023.10.30* @version 0.1* @author Frank**/
public class AlibabaGoldBox5 {public static void main(String[] args) {Scanner sc = new Scanner(System.in);while (sc.hasNext()) {String input = sc.nextLine();String[] inputArr = input.split(",");int[] numbers = new int[inputArr.length];for (int i = 0; i < numbers.length; i++) {numbers[i] = Integer.parseInt(inputArr[i]);}input = sc.nextLine();int k = Integer.parseInt(input);processAlibabaGoldBox5(k, numbers);}}private static void processAlibabaGoldBox5(int k, int[] numbers) {int tmpSum = 0;for (int i = 0; i < k; i++) {tmpSum += numbers[i];}int maxSum = tmpSum;for (int i = 0; i < numbers.length - k; i++) {tmpSum -= numbers[i];tmpSum += numbers[i + k ];if (tmpSum > maxSum) {maxSum = tmpSum;}}System.out.println(maxSum);}}

JavaScript代码

const rl = require("readline").createInterface({ input: process.stdin });
var iter = rl[Symbol.asyncIterator]();
const readline = async () => (await iter.next()).value;
void async function() {while (line = await readline()) {var inputArr = line.split(",");var numbers = new Array();for (var i = 0; i < inputArr.length; i++) {numbers[i] = parseInt(inputArr[i]);}line = await readline()var k = parseInt(line);processAlibabaGoldBox5(k, numbers);}
}();function processAlibabaGoldBox5(k, numbers) {var tmpSum = 0;for (var i = 0; i < k; i++) {tmpSum += numbers[i];}var maxSum = tmpSum;for (var i = 0; i < numbers.length - k; i++) {tmpSum -= numbers[i];tmpSum += numbers[i + k];if (tmpSum > maxSum) {maxSum = tmpSum;}}console.log(maxSum);
}

(完)

这篇关于华为OD机考算法题:阿里巴巴找黄金宝箱(V)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/308499

相关文章

Java中的雪花算法Snowflake解析与实践技巧

《Java中的雪花算法Snowflake解析与实践技巧》本文解析了雪花算法的原理、Java实现及生产实践,涵盖ID结构、位运算技巧、时钟回拨处理、WorkerId分配等关键点,并探讨了百度UidGen... 目录一、雪花算法核心原理1.1 算法起源1.2 ID结构详解1.3 核心特性二、Java实现解析2.

华为鸿蒙HarmonyOS 5.1官宣7月开启升级! 首批支持名单公布

《华为鸿蒙HarmonyOS5.1官宣7月开启升级!首批支持名单公布》在刚刚结束的华为Pura80系列及全场景新品发布会上,除了众多新品的发布,还有一个消息也点燃了所有鸿蒙用户的期待,那就是Ha... 在今日的华为 Pura 80 系列及全场景新品发布会上,华为宣布鸿蒙 HarmonyOS 5.1 将于 7

使用雪花算法产生id导致前端精度缺失问题解决方案

《使用雪花算法产生id导致前端精度缺失问题解决方案》雪花算法由Twitter提出,设计目的是生成唯一的、递增的ID,下面:本文主要介绍使用雪花算法产生id导致前端精度缺失问题的解决方案,文中通过代... 目录一、问题根源二、解决方案1. 全局配置Jackson序列化规则2. 实体类必须使用Long封装类3.

Springboot实现推荐系统的协同过滤算法

《Springboot实现推荐系统的协同过滤算法》协同过滤算法是一种在推荐系统中广泛使用的算法,用于预测用户对物品(如商品、电影、音乐等)的偏好,从而实现个性化推荐,下面给大家介绍Springboot... 目录前言基本原理 算法分类 计算方法应用场景 代码实现 前言协同过滤算法(Collaborativ

售价599元起! 华为路由器X1/Pro发布 配置与区别一览

《售价599元起!华为路由器X1/Pro发布配置与区别一览》华为路由器X1/Pro发布,有朋友留言问华为路由X1和X1Pro怎么选择,关于这个问题,本期图文将对这二款路由器做了期参数对比,大家看... 华为路由 X1 系列已经正式发布并开启预售,将在 4 月 25 日 10:08 正式开售,两款产品分别为华

openCV中KNN算法的实现

《openCV中KNN算法的实现》KNN算法是一种简单且常用的分类算法,本文主要介绍了openCV中KNN算法的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录KNN算法流程使用OpenCV实现KNNOpenCV 是一个开源的跨平台计算机视觉库,它提供了各

springboot+dubbo实现时间轮算法

《springboot+dubbo实现时间轮算法》时间轮是一种高效利用线程资源进行批量化调度的算法,本文主要介绍了springboot+dubbo实现时间轮算法,文中通过示例代码介绍的非常详细,对大家... 目录前言一、参数说明二、具体实现1、HashedwheelTimer2、createWheel3、n

SpringBoot实现MD5加盐算法的示例代码

《SpringBoot实现MD5加盐算法的示例代码》加盐算法是一种用于增强密码安全性的技术,本文主要介绍了SpringBoot实现MD5加盐算法的示例代码,文中通过示例代码介绍的非常详细,对大家的学习... 目录一、什么是加盐算法二、如何实现加盐算法2.1 加盐算法代码实现2.2 注册页面中进行密码加盐2.

Java时间轮调度算法的代码实现

《Java时间轮调度算法的代码实现》时间轮是一种高效的定时调度算法,主要用于管理延时任务或周期性任务,它通过一个环形数组(时间轮)和指针来实现,将大量定时任务分摊到固定的时间槽中,极大地降低了时间复杂... 目录1、简述2、时间轮的原理3. 时间轮的实现步骤3.1 定义时间槽3.2 定义时间轮3.3 使用时

如何通过Golang的container/list实现LRU缓存算法

《如何通过Golang的container/list实现LRU缓存算法》文章介绍了Go语言中container/list包实现的双向链表,并探讨了如何使用链表实现LRU缓存,LRU缓存通过维护一个双向... 目录力扣:146. LRU 缓存主要结构 List 和 Element常用方法1. 初始化链表2.