网站系统php源码,会员系统免费版,骑行网站模板,广州市企业网站建设企业题目
给你一个非负整数数组 nums #xff0c;你最初位于数组的 第一个下标 。数组中的每个元素代表你在该位置可以跳跃的最大长度。
判断你是否能够到达最后一个下标#xff0c;如果可以#xff0c;返回 true #xff1b;否则#xff0c;返回 false 。 示例 1#xff1…题目
给你一个非负整数数组 nums 你最初位于数组的 第一个下标 。数组中的每个元素代表你在该位置可以跳跃的最大长度。
判断你是否能够到达最后一个下标如果可以返回 true 否则返回 false 。 示例 1
输入nums [2,3,1,1,4]
输出true
解释可以先跳 1 步从下标 0 到达下标 1, 然后再从下标 1 跳 3 步到达最后一个下标。示例 2
输入nums [3,2,1,0,4]
输出false
解释无论怎样总会到达下标为 3 的位置。但该下标的最大跳跃长度是 0 所以永远不可能到达最后一个下标。提示
1 nums.length 1040 nums[i] 105 方法一深搜 我们遍历到一个节点分别以nn-1……1步往前走碰到0就结束分支。如果有分支走到最后一个节点说明走到了输出yes。所有分支都结束了但没有分支到最后一个节点输出no。 #includeiostream
using namespace std;
bool flagfalse;
int find(int a[],int n,int x){for(int i0;in;i){if(a[i]x){return 1;}}return 0;
}
int dfs(int a[],int x,int n){if(a[x]0){return 0;}if(xn-1){flagtrue;return 0;}for(int ia[x];i1;i--){dfs(a,xi,n);}}
int main(){freopen(jump.in,r,stdin);freopen(jump.out,w,stdout);int a[10000];int n,p0;cinn;for(int i0;in;i){cina[i];}if(!find(a,n,0)){coutyes;return 0;}dfs(a,0,n);if(flagtrue){coutyes;}else{coutno;}return 0;
}方法二贪心
#includebits/stdc.h
using namespace std;
int main(){int n,a[100],step0;cinn;for(int i0;in;i){cina[i];}for(int i0;istep;i){stepmax(a[i]i,step);if(stepn){coutyes;break;}else{coutno;break;}}return 0;
}