华为OD机试 - 跳格子2 - 动态规划(Java 2024 B卷 100分)

这篇博客介绍了华为在线测评(OD)中的一道跳格子游戏问题,游戏规则是在一个圆圈中选择不相邻的格子跳跃以获取最高分数。博主分享了使用动态规划解决该问题的思路,并提供了Java实现的算法源码,展示了输入输出样例及解释。

一、题目描述

小明和朋友玩跳格子游戏,有n个连续格子组成的圆圈,每个格子有不同的分数,小朋友可以选择从任意格子起跳,但是不能跳连续的格子,不能回头跳,也不能超过一圈。

给定一代表每个格子得分的非负整数数组,计算能够得到的最高分数。

二、输入描述

给定一个数组,第一个格子和最后一个格子首尾相连,比如: 2 3 2

三、输出描述

输出能够得到的最高分,比如:3

四、解题思路

动态规划算法将原问题视作若干个重叠子问题的逐层递进,每个子问题的求解过程都构成一个阶段。

在完成前一个阶段的计算之后,动态规划才会进入到下一个阶段的计算。

动态规划算法解决了“子问题重叠性质”问题,子问题重叠性质是指在用递归算法自顶向下对问题进行求解时,每次产生的子问题并不总是新问题,有些子问题会被重复计算多次。

动态规划算法会对每一个子问题只计算一次,然后将其计算结果保存在一个表格中,当再次需要计算已经计算过的子问题时,只是在表格中简单地查看一下结果,从而获得较高的效率。

  1. 因为①数组首尾相连、②不能连续跳,所以要分而治之,采取动态规划算法;
  2. 包含第一个数字,但不包含最后一个数字的为一组;
  3. 不包含第一个数字,但包含最后一个数字的为一组;
  4. 采取动态规划算法,获取两组数据中的最大值;

五、Java算法源码


                
### 华为 2025 校招考题型与备考建议 华为校招考通常包括三道编程题目,涵盖多种算法和数据结构的知识点。考时间通常为120钟,总为300,题目难度从简单到困难依次递增。题目类型主要集中在以下几个方面: - **基础算法题**:包括字符串处理、数组操作、排序、查找等。 - **数据结构题**:涉及链表、栈、队列、哈希表、树、图等常见数据结构的应用。 - **高级算法题**:如动态规划、贪心算法、回溯法、图论算法(如最短路径、最小生成树)等。 - **综合应用题**:结合多个知识点,要求具备较强的逻辑思维和代码实现能力。 华为考允许在本地IDE编写代码,但禁止使用已有代码库,必须手动编写所有逻辑。考链接通过邮件发送,考生需在7天内完成考,错过则半年内无法再考,因此建议提前做好充准备[^2]。 ### 真题示例与解析 #### 示例题目:格子 III(动态规划) ```java public class JumpGridIII { public static int minJumps(int[] nums) { int n = nums.length; int[] dp = new int[n]; Arrays.fill(dp, Integer.MAX_VALUE); dp[0] = 0; for (int i = 1; i < n; i++) { for (int j = 0; j < i; j++) { if (j + nums[j] >= i) { dp[i] = Math.min(dp[i], dp[j] + 1); } } } return dp[n - 1]; } public static void main(String[] args) { int[] nums = {2, 3, 1, 1, 4}; System.out.println(minJumps(nums)); // 输出 2 } } ``` 该题考查的是动态规划的应用,要求找出从起点到终点所需的最少跃次数。 ### 备考策略 1. **系统学习数据结构与算法**:掌握数组、链表、栈、队列、树、图等基本结构,熟悉排序、查找、动态规划、贪心算法等常见算法。 2. **刷题训练**:建议使用 LeetCode、牛客网等平台刷题,重点关注华为历年真题。可以参考专栏「最新最全真题华为OD真题(全栈版)」,涵盖多种语言版本的题解[^1]。 3. **模拟考环境**:使用在线编辑器练习,适应无IDE提示的环境,提升代码编写速度和准确性。 4. **多语言准备**:华为支持多种语言作答,建议至少掌握一门语言(如 Java、Python、C++)的熟练使用[^3]。 5. **参与交流答疑**:加入相关学习群组或参与线上答疑,解决疑难问题,提升解题技巧。 ### 相关问题 1. 华为校招笔中常见的数据结构有哪些? 2. 如何高效准备华为考中的动态规划题目? 3. 华为考是否允许使用本地IDE编写代码? 4. 华为OD真题可以从哪些渠道获取? 5. 华为校招笔中的编程题通常有哪些类型?
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

哪 吒

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

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

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

打赏作者

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

抵扣说明:

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

余额充值