LeetCode刷题 -- 45.跳跃游戏 II

题目

C代码

c 复制代码
int jump(int* nums, int numsSize) {
    int i = 0;
	int j = 0;
	int last_i = 0;
	int last_can = 0;
	int max_i = 0;
	int max_can = 0;
	
	int min_jump = 0;
	
	if (numsSize < 2) {
		//注意点1:数组小于两个的时候,只需要跳转0次;
		goto end;
	}
	// 注意点2: 当数组数量大于1个的时候,最小跳才是1;因为都是从nums[0]开始跳;
	min_jump++;
	
	last_can = nums[last_i] + last_i;
	max_can = nums[max_i] + max_i;
	
	for (i = 1; i < numsSize; i++) {
		if ((last_i + nums[last_i]) < i) {
			min_jump++;
			last_i = max_i;
			last_can = max_can;
		} else {
			//nothing to do
		}
		// 注意点3: 需要完成跳动后,再把最后这个值更新进系统,因为如果当前这个为最后的值;
		if ((nums[i] + i) < max_can) {
			//nothing to do
		} else {
			max_can = nums[i] + i;
			max_i = i;
		}
	}
end:
	return min_jump;
}
相关推荐
黑色的山岗在沉睡38 分钟前
LeetCode 2761. 和等于目标值的质数对
算法·leetcode·职场和发展
bawangtianzun39 分钟前
重链剖分 学习记录
数据结构·c++·学习·算法
T1an-15 小时前
力扣70.爬楼梯
算法·leetcode·职场和发展
T1an-15 小时前
力扣169.多数元素
数据结构·算法·leetcode
_dindong10 小时前
动规:回文串问题
笔记·学习·算法·leetcode·动态规划·力扣
wangwangmoon_light10 小时前
0.0 编码基础模板
java·数据结构·算法
共享家952710 小时前
Leetcode刷题
算法·leetcode·职场和发展
simon_skywalker11 小时前
第7章 n步时序差分 n步时序差分预测
人工智能·算法·强化学习
山,离天三尺三11 小时前
基于LINUX平台使用C语言实现MQTT协议连接华为云平台(IOT)(网络编程)
linux·c语言·开发语言·网络·物联网·算法·华为云
flashlight_hi11 小时前
LeetCode 分类刷题:74. 搜索二维矩阵
python·算法·leetcode·矩阵