1449 砝码称重 1 秒 (贪心)

1449 砝码称重
1 秒 131,072 KB 40 分 4 级题
现在有好多种砝码,他们的重量是 w0,w1,w2,... 每种各一个。问用这些砝码能不能表示一个重量为m的东西。

样例解释:可以将重物和3放到一个托盘中,9和1放到另外一个托盘中。

思路:

w进制算法,
如果没有天平,只是这些砝码表示m的话,只需要将m表示成w进制数,然后要求每一位不是0就是1.(每个质量的砝码只有一个,要么放,要么不放)
现在有这个天平,n这个数就是 两个 0 1 组成的数之差
因为有借位问题,相差为1是可以的
即只有下面四种情况:

0-0=0 1-0=1 0-1=w-1(向高位借一后) 1-1=0

分为三大类:

第一大类:相应位数之差为0 1的就很明了

第二大类:相应位数之差为w-1的,借位后的那一位在后面给它加上 1 就好了

第三大类:其余情况就是无解了

代码:

package _51_node.greedy;

import java.util.Scanner;

public class ex_1449 {

    /**
     * 1449 砝码称重
     * 1 秒  131,072 KB 40 分 4 级题
     * <p>
     * w进制算法,
     * 如果没有天平,只是这些砝码表示m的话,只需要将m表示成w进制数,然后要求每一位不是0就是1.(每个质量的砝码只有一个,要么放,要么不放)
     * <p>
     * 现在有这个天平,n这个数就是 两个 0 1 组成的数之差
     * 因为有借位问题,相差为1是可以的
     * 即只有下面四种情况:
     *
     * 0-0=0   1-0=1    0-1=w-1(向高位借一后)  1-1=0
     *
     * 分为三大类:
     *
     * 第一大类:相应位数之差为0  1的就很明了
     *
     * 第二大类:相应位数之差为w-1的,借位后的那一位在后面给它加上 1  就好了
     *
     * 第三大类:其余情况就是无解了
     *
     * @param args
     */
    public static void main(String[] args) {
        Scanner cin = new Scanner(System.in);
        int w = cin.nextInt();
        int n = cin.nextInt();
        boolean flag = true;
        while (n != 0) {
            if (n % w == 0 || n % w == 1) n /= w;
            else if ((n + 1) % w == 0) n = (n + 1) / w;
            else {
                flag = false;
                break;
            }
        }
        if (flag) System.out.println("YES");
        else System.out.println("NO");
    }
}

本文作者:somliy

本文链接:https://www.cnblogs.com/somliy/p/10043786.html

版权声明:本作品采用somliy许可协议进行许可。

posted @   somliy  阅读(338)  评论(0编辑  收藏  举报
编辑推荐:
· .NET 9 new features-C#13新的锁类型和语义
· Linux系统下SQL Server数据库镜像配置全流程详解
· 现代计算机视觉入门之:什么是视频
· 你所不知道的 C/C++ 宏知识
· 聊一聊 操作系统蓝屏 c0000102 的故障分析
阅读排行:
· DeepSeek V3 两周使用总结
· 回顾我的软件开发经历(1)
· C#使用yield关键字提升迭代性能与效率
· 低成本高可用方案!Linux系统下SQL Server数据库镜像配置全流程详解
· 4. 使用sql查询excel内容
点击右上角即可分享
微信分享提示
💬
评论
📌
收藏
💗
关注
👍
推荐
🚀
回顶
收起
  1. 1 404 not found REOL
404 not found - REOL
00:00 / 00:00
An audio error has occurred.