之前一直在luogu博客上
2018年12月25日17:18:08 copy到博客园
一道贪心 半dp吧
思路:
分两段处理:
①用膜法打败膜法 全部路程都跑膜法
②全部用腿跑 然后用max(用腿,用膜法)
思路还是很简单的 就是想不到 唉
代码
#include<iostream>
#include<cstdio> #include<algorithm> using namespace std; int M,S,T; int dp[300010]; int main() { cin.sync_with_stdio(false); cin>>M>>S>>T; for(int i=1;i<=T;i++) { if(M>=10) { dp[i]=dp[i-1]+60; M-=10; } else { dp[i]=dp[i-1]; M+=4; } } for(int i=1;i<=T;i++) { dp[i]=max(dp[i],dp[i-1]+17);//核心 if(dp[i]>S) { cout<<"Yes"<<endl<<i; return 0; } } cout<<"No"<<endl<<dp[T]; }