华为OD机试 - 最多获得的短信条数 - 动态规划(Java 2023 B卷 100分)

该博客介绍了华为OD机试中的一道动态规划问题,讨论了如何计算在给定预算下,根据优惠售价序列最多能获得的短信条数。解题思路包括使用动态规划算法,遍历预算和售价序列来更新最大短信条数。同时提供了Java算法源码和效果展示。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、题目描述

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

二、输入描述

  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] + list.get(i - 1) 的较大值,其中 dp[j - i] 表示在剩余预算为 j - i 的情况下获得的短信条数,list.get(i - 1)
### 华为OD中的Java考察内容 华为OD主要针对开发者的算法设计能力、数据结构掌握程度以及实际编码技巧进行评估。以下是关于Java相关的具体考察点和题目类型的析: #### 一、核心考察知识点 1. **基础语法与特性** - Java的基础语法规则,包括变量声明、控制流(if/else, switch)、循环(for, while)等[^1]。 - 对象导向编程的核心概念,如类定义、继承、多态、封装等内容。 2. **常用API与工具库** - 掌握`java.util.*`包下的集合框架,例如List、Set、Map及其子接口的具体实现方式[^3]。 ```java List<String> list = new ArrayList<>(); Set<Integer> set = new HashSet<>(); Map<Character, Integer> map = new HashMap<>(); ``` 3. **异常处理制** - 使用try-catch-finally块捕获并妥善管理运行期错误的能力[^2]。 4. **并发编程** - 多线程环境下资源竞争问题解决方案的理解,比如`synchronized`, `ReentrantLock`的应用场景。 #### 二、典型题目类型 1. **字符串操作** - 字符串匹配、替换、割等问题经常作为入门级挑战出现。例如给定一段文字找出其中重复次数最多的单词。 2. **数组与矩阵变换** - 数组旋转、查找特定模式或者计算最大子序列之和都是高频考点之一。 3. **排序与搜索优化** - 自己动手编写快速排序或其他高效排序方法;熟练运用二法降低时间复杂度。 4. **动态规划求解组合数列** - 动态规划用于解决背包问题变种或是斐波那契数列扩展版本时非常有效果。 5. **图论应用实例** - 图遍历(BFS/DFS), 最短路径(Dijkstra/Floyd-Warshall)等相关理论的实际案例解析。 #### 三、编程测注意事项 - 时间效率考量:确保所选算法能在规定时间内完成运算任务。 - 边界条件验证:考虑极端输入情况是否会引发程序崩溃或逻辑混乱。 - 可读性和可维护性:即使是在限时条件下也应保持清晰易懂的代码风格。 ```java public class Main { public static void main(String[] args){ System.out.println("Hello World!"); } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

哪 吒

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值