【P1095】 守望者的逃离

之前一直在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];
}

 

posted @ 2018-12-25 17:18  _Yrh  阅读(133)  评论(0编辑  收藏  举报