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;
    }
  • 相关阅读:
    STM32驱动TEA5767收音机模块
    stm32驱动DS1302芯片
    NRF24L01无线通讯模块驱动
    MQ-2烟雾传感器启动
    HCSR04超声波传感器驱动
    RDA5820收音机芯片驱动
    SD卡初始化以及命令详解
    STM32硬件IIC操作
    STM32驱动MPU6050
    BMP085气压传感器驱动
  • 原文地址:https://www.cnblogs.com/Chen-Jr/p/11007247.html
Copyright © 2011-2022 走看看