设为首页 加入收藏

TOP

LeetCode - Jump Game
2015-07-20 18:03:24 来源: 作者: 【 】 浏览:4
Tags:LeetCode Jump Game

一开始想DP一步步迭代更新,求出跳到最后一个的最小步数,但是时间复杂度O(nk),会超时。

再一想,发现该题只需要返回能否到达最后一个,不需要最小步数,所以迭代时候只需要保留当前能够走到的最远距离tmpMax,时间复杂度降到O(n)。

class Solution {
public:
	const int MAXVALUE = 1 << 30;
	bool canJump(int A[], int n) {

		int tmpMax = 0;

		if (n == 1)
			return true;

		for (int i = 0; i < n - 1; i++)
		{
			if (i > tmpMax)return false;

			if (tmpMax < i + A[i])
				tmpMax = i + A[i];
			if (tmpMax >= n - 1)
				return true;
		}

		return false;
	}
};


】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇NYOJ-127 星际之门(一) 下一篇HDOJ 4876 ZCC loves cards

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容: