qq直接登录网站无需下载,符合网络营销网站建设,微信小程序是怎么开发的,如何再网站上做免费广告题目#xff1a; 给定一个长度为 n 的 0 索引整数数组 nums。初始位置为 nums[0]。
每个元素 nums[i] 表示从索引 i 向前跳转的最大长度。 返回到达 nums[n - 1] 的最小跳跃次数。
思路#xff1a; 如果某一个作为 起跳点 的格子可以跳跃的距离是 3#xff0c;那么表示后面…题目 给定一个长度为 n 的 0 索引整数数组 nums。初始位置为 nums[0]。
每个元素 nums[i] 表示从索引 i 向前跳转的最大长度。 返回到达 nums[n - 1] 的最小跳跃次数。
思路 如果某一个作为 起跳点 的格子可以跳跃的距离是 3那么表示后面 3 个格子都可以作为 起跳点。 1.1. 可以对每一个能作为 起跳点 的格子都尝试跳一次把 能跳到最远的距离 不断更新。 如果从这个 起跳点 起跳叫做第 1 次 跳跃那么从后面 3 个格子起跳 都 可以叫做第 2 次 跳跃。 所以当一次 跳跃 结束时从下一个格子开始到现在 能跳到最远的距离都 是下一次 跳跃 的 起跳点。 3.1. 对每一次 跳跃 用 for 循环来模拟。 3.1.1跳完一次之后更新下一次 起跳点 的范围。 3.1.2在新的范围内跳更新 能跳到最远的距离。 记录 跳跃 次数如果跳到了终点就得到了结果。 C
#includeiostream
#includevector
#includealgorithm
using namespace std;class Solution
{
public:int jump(vectorint nums){int times 0;int start 0;int end 1;int n nums.size();while(end n){int maxPose 0;for(int i start; iend; i){// 能跳到的最远距离maxPose max(maxPose,inums[i]);}start end; // 下一次起跳范围开始的格子end maxPose 1; // 下一次起跳范围结束的格子times;}return times;}
};