zoukankan      html  css  js  c++  java
  • 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;
    }
  • 相关阅读:
    常用的系统操作需要的响应时间
    几种RAID技术比较
    iptables详解
    mount命令详解
    解决CSocket高数据传输问题
    VC++ ComBox下拉菜单看不到值
    封装MySQL C API 基本操作
    MySQL存储过程和存储函数
    MYSQL 常用命令
    VS2005连接MySQL C API
  • 原文地址:https://www.cnblogs.com/Chen-Jr/p/11007247.html
Copyright © 2011-2022 走看看