Codeforces 1015D(贪心)

传送门

题目描述:

    在一条数轴上有编号为1到n的n座房子,每次必须移动,移动的距离为两点坐标之差的绝对值,问能否在k回合里一共移动s距离。

题目分析:

    我们考虑进行贪心。显然,当我们需要移动的距离s大于k次可以移动的最大值k*(n-1),以及当需要移动的步数小于k次可以移动的最小值k时,显然不符合题意。而显然在其他情况下人必定可以用各种方式成功移动的。

    之后我们就要考虑贪心。为了尽早的接近目的地(达到某个走n格可以到达的地方),我们需要优先的每次走最大的步数n-1。而倘若现在已经到达了一个走n格可以达到的地方,我们只需要让走的步数s跟随着次数k变化(每次使s-(s-(k-i)) )即可。

#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
int main()
{
    ll n,k,s;
    cin>>n>>k>>s;
    if(s>(n-1)*k){
        puts("NO");
        return 0;
    }
    if(s<k){
        puts("NO");
        return 0;
    }
    puts("YES");
    ll res=1;
    for(int i=1;i<=k;i++){
    //如果在n格以外,则不断取最大的,而如果在目的地在n格以内可以达到,则让步数随着次数变化即可。
        ll tmp=min(n-1,s-(k-i));
        s-=tmp;
        if(res==1) res+=tmp;
        else res-=tmp;
        cout<<res<<" ";
    }
    return 0;
}

猜你喜欢

转载自blog.csdn.net/weixin_39453270/article/details/81395245