华为OD机试真题 JavaScript 实现【最多获得的短信条数】【2023Q1 100分】,附详细解题思路

news2024/12/28 4:33:10

在这里插入图片描述

一、题目描述

某云短信厂商,为庆祝国庆,推出充值优惠活动。现在给出客户预算,和优惠售价序列,求最多可获得的短信总条数。

二、输入描述

  1. 第一行客户预算M,其中 0 ≤ M ≤ 10^6
  2. 第二行给出售价表, P1, P2, … Pn , 其中 1 ≤ n ≤ 100 ,

Pi为充值 i 元获得的短信条数。

1 ≤ Pi ≤ 1000 , 1 ≤ n ≤ 100

三、输出描述

最多获得的短信条数。

四、解题思路

  1. 读取输入的客户预算 budget 和优惠售价序列 list;
  2. 创建一个长度为 budget + 1 的数组 dp,用于存储在不同预算下可获得的最多短信条数;
  3. 使用动态规划计算最多获得的短信条数:
    • 遍历优惠售价序列 list,对于每个售价 i,遍历从0到预算的所有金额 j。
    • 如果当前金额 j 大于等于当前售价 i,更新 dp[j] 为 dp[j] 和 dp[j - i - 1] + list[i] 的较大值,其中 dp[j - i - 1] 表示在剩余预算为j - i - 1 的情况下获得的短信条数,list[i] 表示当前售价 i 对应的短信条数。
  4. 输出 dp[budget],即在给定预算下可获得的最多短信条数。

五、JavaScript 算法源码

// 读取输入的客户预算 budget 和优惠售价序列 list
function calculateMaxSMS(budget, list) {
    // 使用动态规划计算最多获得的短信条数
    const dp = new Array(budget + 1).fill(0);

    // 遍历优惠售价序列 list,对于每个售价 i,遍历从0到预算的所有金额 j。
    for (let i = 0; i < list.length; i++) {
        for (let j = 1; j <= budget; j++) {
            if (j >= i + 1) {
                dp[j] = Math.max(dp[j], dp[j - i - 1] + list[i]);
            }
        }
    }

    return dp[budget];
}

六、效果展示

1、输入

12

2、输出

[10,20,50,70,90,130,180]

在这里插入图片描述


🏆下一篇:华为OD机试真题 JavaScript 实现【相对开音节】【2022Q4 100分】,附详细解题思路

🏆本文收录于,华为OD机试(JavaScript)真题(A卷+B卷)

每一题都有详细的答题思路、详细的代码注释、样例测试,订阅后,专栏内的文章都可看,可加入华为OD刷题群(私信即可),发现新题目,随时更新,全天CSDN在线答疑。

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/671400.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

一切美好如夏而至,中国人民大学与加拿大女王大学金融硕士项目陪你逐梦硕士

流光半夏&#xff0c;美好日长。愿所有春天里的酝酿&#xff0c;都在夏天热烈绽放。你春天酝酿的读研梦有实现吗&#xff1f;在这个最长的白昼&#xff0c;让我们与中国人民大学与加拿大女王大学金融硕士项目邂逅&#xff0c;一起在盛夏里追寻诗与远方。 都说有梦想&#xff0…

【07】STM32·HAL库开发-新建寄存器版本MDK工程 |下载STM32Cube固件包 | 新建MDK工程步骤

目录 1.新建工程前的准备工作&#xff08;了解&#xff09;1.1下载相关STM32Cube 官方固件包&#xff08;F1/F4/F7/H7) 2.新建寄存器版本MDK工程步骤&#xff08;熟悉&#xff09;2.1新建工程文件夹2.1.1Drivers文件夹2.1.2Middlewares文件夹2.1.3Output文件夹2.1.4Projects文件…

零基础入门网络安全,收藏这篇不迷茫【2022 最新】

前言 最近收到不少关注朋友的私信和留言&#xff0c;大多数都是零基础小友入门网络安全&#xff0c;需要相关资源学习。其实看过的铁粉都知道&#xff0c;之前的文里是有过推荐过的。新来的小友可能不太清楚&#xff0c;这里就系统地叙述一遍。 01.简单了解一下网络安全 说白…

ASEMI代理光宝光耦LTV-61L的工作原理与应用探析

编辑-Z 本文将对光耦LTV-61L进行深入的探讨&#xff0c;主要从其工作原理、应用领域、使用注意事项以及市场前景四个方面进行详细的阐述。光耦LTV-61L是一种常用的光电器件&#xff0c;其工作原理简单&#xff0c;应用领域广泛&#xff0c;但在使用过程中也需要注意一些问题。…

1分钟!免费将AI图像创作能力接入办公系统

随着人工智能技术的日新月异&#xff0c;各行各业都在尝试将AI技术融入到自己的生产和服务中以提升效率和用户体验&#xff0c;绘画领域也在迎来一轮新的生产方式革新。在数字绘画领域&#xff0c;AI绘图软件的出现&#xff0c;为数字绘画领域注入了新的活力。 但我们在使用AI绘…

【正点原子STM32连载】第三十八章 CAN通讯实验 摘自【正点原子】STM32F103 战舰开发指南V1.2

1&#xff09;实验平台&#xff1a;正点原子stm32f103战舰开发板V4 2&#xff09;平台购买地址&#xff1a;https://detail.tmall.com/item.htm?id609294757420 3&#xff09;全套实验源码手册视频下载地址&#xff1a; http://www.openedv.com/thread-340252-1-1.html# 第三…

VXLAN 主机VTEP(OVN)

EVE环境模拟搭建一个基于主机VTEP的VXLAN数据中心网络。 实验里vtep是在linux主机上&#xff0c;同时linux主机还得有路由功能使VTEP的端点IP可达&#xff0c;所以两台linux服务器需要安装FRR。 数据转发平面使用VXLAN封装&#xff1b;在控制平面我打算选择使用EVPN和OVN两种不…

Golang每日一练(leetDay0101) 最长递增子序列I\II\个数

目录 300. 最长递增子序列 Longest Increasing Subsequence &#x1f31f;&#x1f31f; 2407. 最长递增子序列 II Longest Increasing Subsequence ii &#x1f31f;&#x1f31f;&#x1f31f; 673. 最长递增子序列的个数 Number of Longest Increasing Subsequence &a…

YOLOv5/v7 添加注意力机制,30多种模块分析⑥,S2-MLPv2模块,NAM模块

目录 一、注意力机制介绍1、什么是注意力机制&#xff1f;2、注意力机制的分类3、注意力机制的核心 二、S2-MLPv2模块1、 S2-MLPv2模块的原理2、实验结果3、应用示例 三、NAM模块1、NAM 的原理2、实验结果3、应用示例 大家好&#xff0c;我是哪吒。 &#x1f3c6;本文收录于&a…

【Duilib】资源打包入EXE

环境 VS版本&#xff1a;VS2013 概述 资源打包成ZIP&#xff0c;ZIP文件放置EXE内部。 步骤 1、按上一篇建好工程。 2、RC文件添加ZIP资源。 这一步比较复杂&#xff0c;工程 添加资源&#xff0c;弹窗如下右侧对话框后&#xff0c;按①②③④步骤&#xff0c;找到theme.z…

Springboot项目使用原生Websocket

目录 1.启用Websocket功能2.封装操作websocket session的工具3.保存websocket session的接口4.保存websocket session的类5.定义websocket 端点6.创建定时任务 ping websocket 客户端 1.启用Websocket功能 package com.xxx.robot.config;import org.springframework.context.a…

机器学习实践(1.2)XGBoost回归任务

前言 XGBoost属于Boosting集成学习模型&#xff0c;由华盛顿大学陈天齐博士提出&#xff0c;因在机器学习挑战赛中大放异彩而被业界所熟知。相比越来越流行的深度神经网络&#xff0c;XGBoost能更好的处理表格数据&#xff0c;并具有更强的可解释性&#xff0c;还具有易于调参…

Axure教程—树

本文将教大家如何用AXURE中的动态面板制作树 一、效果 预览地址&#xff1a;https://1rmtjd.axshare.com 二、功能 1、点击“”&#xff0c;展开子节点 2、点击“-”子节点折叠 三、制作 1、父节点制作 拖入一个动态面板&#xff0c;进入&#xff0c;如图&#xff1a; 拖入一…

【LeetCode】HOT 100(18)

题单介绍&#xff1a; 精选 100 道力扣&#xff08;LeetCode&#xff09;上最热门的题目&#xff0c;适合初识算法与数据结构的新手和想要在短时间内高效提升的人&#xff0c;熟练掌握这 100 道题&#xff0c;你就已经具备了在代码世界通行的基本能力。 目录 题单介绍&#…

【玩转Docker小鲸鱼叭】Docker容器常用命令大全

在 Docker 核心概念理解 一文中&#xff0c;我们知道 Docker容器 其实就是一个轻量级的沙盒&#xff0c;应用运行在不同的容器中从而实现隔离效果。容器的创建和运行是以镜像为基础的&#xff0c;容器可以被创建、销毁、启动和停止等。本文将介绍下容器的这些常用操作命令。 1、…

max^2 - min^2

2001^2- 2000^2 ???? max^2 - min^2min * (max - min) min * (max - min) (max - min)* (max - min) min * (max - min) * 2 (max - min)* (max - min) (max min)(max - min)

管理类联考——逻辑——技巧篇——形式逻辑——秒杀思路

第一章&#xff1a;说明 形式逻辑出现频次 8-10 道 形式逻辑细分思路 直言命题三段论与文氏图AEIO 与模态命题形式逻辑复合命题固定秒杀思路 说明1&#xff1a; AEIO 全称肯定命题&#xff1a;所有 S 都是 P&#xff0c;记作 SAP。 简称为“A” 全称否定命题&#xff1a;所…

TCL、海信、小米密集推新,Mini LED电视熬出头了

作者 | 辰纹 来源 | 洞见新研社 OLED和Mini LED之间的对决来到了赛点。 进入2023年&#xff0c;一线电视厂商发布的新品中&#xff0c;Mini LED成为主流。 3月2日&#xff0c;索尼全球发布了其2023年BRAVIA XR 电视新品阵容。其中&#xff0c;索尼Mini LED电视X95L采用Mini …

MFC学习之修改设置控件字体显示和颜色参数

前言 最近一直配合研发部门写一些调试类的小软件&#xff0c;记得之前电脑显示器和显卡配置都不高&#xff0c;显示分辨率比较低&#xff0c;软件界面上的文字还能看到清楚&#xff08;不显小&#xff09;。 现在公司新配置的电脑都比较好了&#xff0c;界面字体&#xff0c;尤…

【高性能计算】监督学习之支持向量机分类实验

【高性能计算】监督学习之支持向量机分类实验 实验目的实验内容实验步骤1、支持向量机算法1.1 支持向量机算法的基本思想1.2 支持向量机算法的分类过程1.3 支持向量机算法的模型构建过程 2、使用Python语言编写支持向量机的源程序代码并分析其分类原理2.1 支持向量机SVM模型代码…