算法-盒子中小球的最大数量

ops/2025/1/15 14:53:43/

原题目链接:1742. 盒子中小球的最大数量 - 力扣(LeetCode)

你在一家生产小球的玩具厂工作,有 n 个小球,编号从 lowLimit 开始,到 highLimit 结束(包括 lowLimit 和 highLimit ,即 n == highLimit - lowLimit + 1)。另有无限数量的盒子,编号从 1 到 infinity 。

你的工作是将每个小球放入盒子中,其中盒子的编号应当等于小球编号上每位数字的和。例如,编号 321 的小球应当放入编号 3 + 2 + 1 = 6 的盒子,而编号 10 的小球应当放入编号 1 + 0 = 1 的盒子。

给你两个整数 lowLimit 和 highLimit ,返回放有最多小球的盒子中的小球数量如果有多个盒子都满足放有最多小球,只需返回其中任一盒子的小球数量。

示例 1:

输入:lowLimit = 1, highLimit = 10
输出:2
解释:
盒子编号:1 2 3 4 5 6 7 8 9 10 11 ...
小球数量:2 1 1 1 1 1 1 1 1 0  0  ...
编号 1 的盒子放有最多小球,小球数量为 2 。

示例 2:

输入:lowLimit = 5, highLimit = 15
输出:2
解释:
盒子编号:1 2 3 4 5 6 7 8 9 10 11 ...
小球数量:1 1 1 1 2 2 1 1 1 0  0  ...
编号 5 和 6 的盒子放有最多小球,每个盒子中的小球数量都是 2 。

示例 3:

输入:lowLimit = 19, highLimit = 28
输出:2
解释:
盒子编号:1 2 3 4 5 6 7 8 9 10 11 12 ...
小球数量:0 1 1 1 1 1 1 1 1 2  0  0  ...
编号 10 的盒子放有最多小球,小球数量为 2 。

提示:

  • 1 <= lowLimit <= highLimit <= 10^5
    import java.util.ArrayList;
    import java.util.HashMap;
    import java.util.List;
    import java.util.Map;class Solution {//计算个位数之和public static int geweiSum(int n){int sum =0;while(n>0){sum=sum+n%10;n=n/10;}return sum;}//个位数之和相同最多的盒子public static int countBalls(int lowLimit, int highLimit) {// 创建一个HashMap来存储每个数字及其出现的次数Map<Integer, Integer> frequencyMap = new HashMap<>();List<Integer> numbers=new ArrayList<>();for(int i= lowLimit;i<=highLimit;i++){numbers.add(geweiSum(i));}
    //        System.out.println(numbers);// 遍历列表,更新HashMap中的计数for (int number : numbers) {if (frequencyMap.containsKey(number)) {frequencyMap.put(number, frequencyMap.get(number) + 1);} else {frequencyMap.put(number, 1);}}
    //        System.out.println(frequencyMap);// 查找出现次数最多的数字int mostFrequentNumber = -1;int maxCount = 0;for (Map.Entry<Integer, Integer> entry : frequencyMap.entrySet()) {if (entry.getValue() > maxCount) {maxCount = entry.getValue();mostFrequentNumber = entry.getValue();}}return mostFrequentNumber;}//    public static void main(String[] args) {
    //        System.out.println(countBalls(1,10));
    //    }
    }


http://www.ppmy.cn/ops/150314.html

相关文章

如何开放2375和2376端口供Docker daemon监听

Linux (以 Ubuntu 为例) 1. 修改 Docker 配置文件 打开 Docker 的配置文件 /etc/docker/daemon.json。如果该文件不存在&#xff0c;则可以创建一个新的。 bash sudo nano /etc/docker/daemon.json在配置文件中添加以下内容&#xff1a; json {"hosts": ["un…

C#,任意阶幻方(Magic Square)的算法与源代码

1 什么是幻方&#xff1f; 幻方&#xff08;Magic Square&#xff09;是一种将数字安排在正方形格子中&#xff0c;使每行、列和对角线上的数字和都相等的方法。 幻方也是一种中国传统游戏。旧时在官府、学堂多见。它是将从一到若干个数的自然数排成纵横各为若干个数的正方形&…

【机器学习】实战:天池工业蒸汽量项目(一)数据探索

文章目录 1、项目介绍2、导入数据探索工具包3、数据加载4、查看数据集变量信息5、查看数据统计信息6、查看数据字段信息7、箱式图数据探索8、查看数据分布9、特征相关性10、特征筛选 个人主页&#xff1a;道友老李 欢迎加入社区&#xff1a;道友老李的学习社区 【机器学习】实…

linux自动分区后devmappercentos-home删除后合并到其它分区上

删除其他分区&#xff0c;合并到对应分区上增加磁盘空间 删除开机默认挂载 /dev/mapper/centos-home vim /etc/fstab 把 /dev/mapper/centos-home 这一行删除掉命令行取消挂载 /dev/mapper/centos-home umount /dev/mapper/centos-home删除掉逻辑卷 home lvsdf -hlvremove /…

AI时代来了,我们不再需要IDE了

大家好&#xff0c;我是编程乐趣。 最近在思考一个问题&#xff0c;那就是AI这么强大。 未来有没有可能&#xff0c;我们就不需要不需要开发工具了&#xff0c;只需一个浏览器就可以开发软件了。 一、AI带来的变化 1、代码生成与补全 AI工具如GitHub Copilot等能够根据代码…

openEuler 22.04使用yum源最快速度部署k8s 1.20集群

本文目的 openEuler的官方源里有kubernetes 1.20&#xff0c;使用yum源安装是最快部署一个k8s集群的办法 硬件环境 主机名系统架构ipmasteropenEuler release 22.03 (LTS-SP2)arm192.168.3.11edgeopenEuler release 22.03 (LTS-SP2)arm192.168.3.12deviceopenEuler release 22.…

机器学习算法(一): 基于逻辑回归的分类预测

1 逻辑回归的介绍和应用 1.1 逻辑回归的介绍 逻辑回归&#xff08;Logistic regression&#xff0c;简称LR&#xff09;虽然其中带有"回归"两个字&#xff0c;但逻辑回归其实是一个分类模型&#xff0c;并且广泛应用于各个领域之中。虽然现在深度学习相对于这些传统…

UML系列之Rational Rose笔记八:类图

一、新建类图 首先依旧是新建要绘制的类图&#xff1b;选择class diagram&#xff1b; 修改命名&#xff1b; 二、工作台介绍 正常主要就是使用到class还有直接关联箭头就行&#xff1b; 如果不要求规范&#xff0c;直接新建一些需要的类&#xff0c;然后写好关系即可&#…