第一题帮朋友做的,AC了 LUCKY BOY<zhang.yun.hao@foxmail.com> 16:26:24 #include<iostream> #include<vector> using namespace std; int main() { int n; cin >> n; vector<int> vec; vector<int> dp(n + 1, -1); for (int i = 0; i < n; i++) { int tmp; cin >> tmp; vec.push_back(tmp); } dp[0] = 0; for (int i = 1; i <= n; i++) { int min = 99999; //从i节点之前找到可以跳到i的一个节点,该节点必须可到达,即不为-1 for (int j = 0; j < i; j++) { if (vec[j] >= i - j) { if (min > dp[j] && dp[j] != -1) min = dp[j]; } } dp[i] = (min == 99999 ? -1 : min + 1); } cout << dp[n] << endl; }
点赞 评论

相关推荐

不愿透露姓名的神秘牛友
07-07 12:04
毕业生招你惹你了,问一个发薪日来一句别看网上乱七八糟的你看哪个工作没有固定发薪日扭头就取消了面试就问了一句公司都是这个态度吗还搞上人身攻击了...
程序员小白条:呃呃呃,都还没面试,我都不会问这么细,何况通不通过,去不去都另说,你没实力和学历的话,在外面就这样,说实话没直接已读不回就不错了,浪费时间基本上
点赞 评论 收藏
分享
强大的马里奥:不太可能,我校计算机硕士就业率99%
点赞 评论 收藏
分享
兄弟们,实习都是在接各种api,该怎么包装简历
仁者伍敌:感觉我自己做小项目也是各种api啊,我要怎么包装简历
点赞 评论 收藏
分享
牛客网
牛客网在线编程
牛客网题解
牛客企业服务