首页 > 其他分享 >AcWing——砝码称重

AcWing——砝码称重

时间:2023-06-08 22:37:53浏览次数:46  
标签:10 天平 砝码 物品 称重 重量 AcWing

4942. 砝码称重 - AcWing题库

1、题目

给定一个天平和 101 个砝码。

101 个砝码的重量依次为 n⁰,n¹,n²,…,n¹⁰⁰ 克,其中 n 是一个不小于 2 的整数。

请你判断,我们能否利用给定天平和砝码对重量为 m 克的物品进行称重。

注意,天平的两端都可以放入砝码。

具体来说,你的任务是判断是否可以在天平的左盘放入重量为 m克的物品以及一些砝码(也可以不放砝码),并在天平的右盘放入一些砝码,从而使得天平的两端可以保持平衡。

不要求用到所有砝码,挑选合适的砝码使用即可。

例如,如果 n=3,m=7,则我们可以在天平的左盘放入重量为 7 克的物品以及重量为 3 克的砝码,并在天平的右盘放入重量为 1,9克的砝码,这样可以使得天平两端保持平衡。

输入格式

共一行,包含两个整数 n,m。

输出格式

如果可以对重量为 m 克的物品进行称重,则输出 YES,否则输出 NO。

数据范围

前 5 个测试点满足 2≤n≤100,1≤m≤100。

所有测试点满足 2≤n≤10⁹,1≤m≤10⁹。

输入样例1:

3 7

输出样例1:

YES

输入样例2:

100 99

输出样例2:

YES

2、题目解读

题目会给两个数,n和m,要求我们可以使用 101 个砝码(101 个砝码的重量依次 为 n⁰,n¹,n²,…,n¹⁰⁰ 克,其中 n 是一个不小于 2 的整数)。是否可以在天平的左盘放入重量为 m克的物品以及一些砝码(也可以不放砝码),并在天平的右盘放入一些砝码,从而使得天平的两端可以保持平衡。

这可以转化成m是否可以由n进制表示出来,但是n进制上面的数只能是0(不放),1(放在物品对面),-1(放在物品这边),所以我们只需要求n进制的m每一位上面是否是0,1,-1,如果不是则说明无法对重量为 m克的物品进行称重,输出NO。

此时有小伙伴就发现了

m, n都是正数啊,两个取余不可能得到-1这个结果,那我们应该怎么办?

我们把判断 -1 换成判断 n-1

为什么可以这样换?Java中余数可以是负数,在数学中余数不能是负数

举个例子:-9%10 = -9(Java表示),-9%10 = -1* 10 + 1(数学表示);

发现什么没,左边的 -9 和右边的 10 - 9 = 1 是一样的;

所以我们可以把判断-1换成判断n-1

10 9

9= -1 * 10⁰ + 1*10¹

3、代码

import java.util.Scanner;
 
public class Main {
    public static void main(String[] args) {
        Scanner sc=new Scanner(System.in);
        int n=sc.nextInt();
        int m=sc.nextInt();
        while (m!=0){
            int i=m%n;
            if (i!=0&&i!=1&&i!=n-1){
                System.out.println("NO");
                return;
            }
            if (i > 1)//i=n-1 转换回 n=-1
                i = -1;
            m = (m - i) / n;
        }
        System.out.println("YES");
    }
}


标签:10,天平,砝码,物品,称重,重量,AcWing
From: https://blog.51cto.com/u_15409921/6443757

相关文章

  • 【acwing】Trie字符串统计
    Trie树学习感受相比于之前学习的kmp匹配算法,Trie树的实现还是非常好理解的。(kmp算法太难了orz)从直观的模拟过程来看,trie树就像一颗树一样,从上(根节点)到下(叶节点)有序串联起来组成一个字符串。每一个额外标记结束的位置表示字符串的结束,通过计算标记数即可指导一共有多少该字符串......
  • 【每日一题】AcWing 1904. 奶牛慢跑
    题目奶牛们又出去锻炼蹄子去了!有N头奶牛在无限长的单行道上慢跑。每头奶牛在跑道上开始奔跑的位置互不相同,一些奶牛的奔跑速度可能相同,也可能不同。由于跑道是单行道,十分狭窄,奶牛们无法相互超越。当一头速度很快的牛追上另一头牛时,她必须减速至与另一头牛速度相同以免发生碰撞,并成......
  • 【蓝桥杯集训·每日一题】AcWing 3805. 环形数组
    写在前面本人CSDN博客主页:这里一、题目1、原题链接3805.环形数组2、题目描述给定一个长度为n的环形数组a0,a1,…,an−1。现在要对该数组进行m次操作。操作分为以下两种:增值操作lrd,将区间[l,r]上的每个元素都增加d。求最小值操作lr,输出区间[l,r]内的所有元素的最小......
  • 【蓝桥杯集训·每日一题】AcWing 1079. 叶子的颜色
    写在前面本人CSDN博客主页:这里一、题目1、原题链接1079.叶子的颜色2、题目描述给一棵有m个节点的无根树,你可以选择一个度数大于1的节点作为根,然后给一些节点(根、内部节点、叶子均可)着以黑色或白色。你的着色方案应保证根节点到各叶子节点的简单路径上都至少包含一个有色节点,哪......
  • 【蓝桥杯集训·每日一题】AcWing 4496. 吃水果
    写在前面本人CSDN博客主页:这里一、题目1、原题链接4496.吃水果2、题目描述n个小朋友站成一排,等着吃水果。一共有m种水果,每种水果的数量都足够多。现在,要给每个小朋友都发一个水果,要求:在所有小朋友都拿到水果后,恰好有k个小朋友拿到的水果和其左边相邻小朋友拿到的水果不同(最左......
  • 前缀和 (Acwing_796 子矩阵的和)
    题目1.S[i,j]即为图1红框中所有数的的和为:S[i,j]=S[i,j−1]+S[i−1,j]−S[i−1,j−1]+a[i,j]2.(x1,y1),(x2,y2)这一子矩阵中的所有数之和为:S[x2,y2]−S[x1−1,y2]−S[x2,y1−1]+S[x1−1,y1−1]#include<iostream>usingnamespacestd;constintN=1e3+10;int......
  • 【蓝桥杯集训·每日一题】AcWing 4309. 消灭老鼠
    写在前面本人CSDN博客主页:这里一、题目1、原题链接4309.消灭老鼠2、题目描述约翰的农场可以看作一个二维平面。农场中有n个老鼠,在毁坏着农田。第i个老鼠的位置坐标为(xi,yi)。不同老鼠可能位于同一位置。在(x0,y0)处,装有一个双向发射的激光枪,该位置没有老鼠。激光枪每次发......
  • 【蓝桥杯集训·每日一题】AcWing 3625. 幂次方
    写在前面本人CSDN博客主页:这里一、题目1、原题链接3625.幂次方2、题目描述对任意正整数N,计算XNmod233333的值。输入格式共一行,两个整数X和N。输出格式共一行,一个整数,表示XNmod233333的值。数据范围1≤X,N≤109输入样例:25输出样例:32二、解题报告1、思路分析(1)快速幂模板题......
  • Acwing 798.差分矩阵(模板)
    题目#include<iostream>usingnamespacestd;constintN=1010;intn,m,q;inta[N][N],b[N][N];voidinsert(intx1,inty1,intx2,inty2,intc){b[x1][y1]+=c;b[x2+1][y1]-=c;b[x1][y2+1]-=c;b[x2+1][y2+1]+=......
  • AcWing905.区间选点
    题目详情知识点区间贪心为什么叫贪心呢?——短视,每次只是在看眼前的东西,在眼前的决策中选一个最优解。而贪心就是根据这种策略能够走到全局最优解的方法【如果用函数图像来表示就是一个单峰的图】贪心的普遍方案一般来说贪心问题没有思路的时候我们可以先随便试一下,再去举一......