题解 | #称砝码#

称砝码

https://www.nowcoder.com/practice/f9a4c19050fc477e9e27eb75f3bfd49c

高赞的代码解析:

思路是枚举,以题目给的案例,按照习惯可轻松写出不同的重量组合,但是每种重量的砝码组合可能会有多种,需要去重。

将每种砝码从1个到最大数量时所能表示的重量都放入哈希表中,每次放入之前,先遍历哈希表,取出前一种砝码的所有重量,每取一个就进行组合,组合后的重量再放回哈希表种,由此得到最终结果。

import java.util.*;

public class Main {
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        while (in.hasNextInt()) { // 注意 while 处理多个 case
            HashSet<Integer> set = new HashSet<>();//去重存放所有可能的结果
            set.add(0);//初始化为0,0是唯一一个已知的可以表示的重量
            int n = in.nextInt();//砝码种类数
            int[] w = new int[n];//砝码重量
            int[] nums = new int[n];//砝码数量
            for (int i = 0; i < n; i++) {
                w[i] = in.nextInt();//砝码的重量
            }
            for (int i = 0; i < n; i++) {
                nums[i] = in.nextInt();//砝码个数
            }
            for (int i = 0; i < n; i++) { //遍历砝码:i是砝码种类
                //截止目前,已用过的砝码可表示的不同重量数
                ArrayList<Integer> list = new ArrayList<>(set);
                for (int j = 1; j <= nums[i];j++) { //遍历个数,nums[i]是砝码i的数量,砝码i的使用数量从1到nums[i]
                    int jW = w[i] * j;
                    for (int k = 0; k < list.size(); k++) {
                        int tempW = list.get(k);
                        //更新set中的重量终类
                        set.add(tempW + jW); //j个砝码i的重量:w[i] * j
                    }
                }
            }
            System.out.println(set.size());
        }
    }
}
全部评论

相关推荐

ALEX_BLX:虽然说聊天记录不可信,不过这个趋势确实如此但我觉得也要想到一点就是卷后端的人里真正有“料”的人又有多少,我说的这个料都不是说一定要到大佬那种级别,而是就一个正常的水平。即使是现在也有很多人是跟风转码的,2-3个月速成后端技术栈的人数不胜数,但今时不同往日没可能靠速成进大厂了。这种情况就跟考研一样,你能上考场就已经打败一半的人了
点赞 评论 收藏
分享
昨天 18:20
电子科技大学 C++
Aki-Tomoya:7点下班我吃
投递字节跳动等公司6个岗位
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务