如何统计1到100中每个数字(0–9)出现的次数

发布时间 - 2026-01-12 00:00:00    点击率:

文介绍一种高效、简洁的java方法,通过取模和整除运算逐位提取数字,统计1至100范围内每个数字0–9在所有整数中的总出现次数,避免字符串转换与异常处理,代码健壮且易于理解。

在统计数字频次类问题中,将整数转为字符串再逐字符比较(如 charAt() + String.valueOf())虽直观,但存在明显缺陷:逻辑冗余、易出错(如越界异常)、可读性差,且性能开销大。更优解是采用纯数学方法——利用整数的十进制特性,通过 x % 10 获取个位数字,再用 x /= 10(即 x = x / 10)去掉该位,循环直至数值归零。

以下是推荐实现:

public class CountEachDigit {
    public static void main(String... args) {
        final int lo = 1;
        final int hi = 100;
        int[] digits = countDigits(lo, hi);

        for (int i = 0; i < 10; i++) {
            System.out.format("The digit %d appears %d times between %d and %d.\n", 
                              i, digits[i], lo, hi);
        }
    }

    private static int[] countDigits(int lo, int hi) {
        int[] digits = new int[10]; // 索引0~9对应数字0~9的计数

        for (int num = lo; num <= hi; num++) {
            int val = num;
            do {
                digits[val % 10]++; // 提取并统计当前个位数字
            } while ((val /= 10) > 0); // 去掉个位,继续处理高位
        }

        return digits;
    }
}

关键原理说明:

  • val % 10 恒返回 val 的最低位数字(例如 105 % 10 == 5,10 % 10 == 0,7 % 10 == 7);
  • val /= 10 是整数除法,等效于去掉个位(如 105 / 10 == 10,10 / 10 == 1,1 / 10 == 0);
  • do-while 循环确保即使 num 为个位数(如 5),也能至少执行一次计数,之后 5/10==0 退出。

运行结果:

The digit 0 appears 11 times between 1 and 100.
The digit 1 appears 21 times between 1 and 100.
The digit 2 appears 20 times between 1 and 100.
...
The digit 9 appears 20 times between 1 and 100.

优势总结:

  • 无异常风险:不依赖字符串索引,彻底规避 StringIndexOutOfBoundsException;
  • 逻辑清晰:核心逻辑仅3行,符合“单一职责”原则;
  • 可扩展性强:只需修改 lo/hi 即可适配任意正整数区间(如 1–1000);
  • 性能优越:避免字符串对象创建与内存分配,时间复杂度为 O(N × log₁₀M),其中 N 为数字个数,M 为最大数值。

⚠️ 注意事项:

  • 该方法默认统计所有数字位(如 100 贡献一个 '1' 和两个 '0'),符合题目要求;
  • 若需排除前导零(如不统计 007 中的 0),则需额外判断位数,但本题范围(1–100)中无前导零问题;
  • 数组 digits 初始化为 int[10],自动填充 0,无需手动清零。

掌握这种“模10取位 + 整除去位”的模式,是解决数字拆分、回文判断、进制转换等基础算法问题的关键基石。


# java  # git  # app  # ai 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel怎么返回JSON格式数据_Laravel API资源Response响应格式化【技巧】  Laravel如何与Docker(Sail)协同开发?(环境搭建教程)  创业网站制作流程,创业网站可靠吗?  C#如何调用原生C++ COM对象详解  Laravel如何为API生成Swagger或OpenAPI文档  Laravel如何清理系统缓存命令_Laravel清除路由配置及视图缓存的方法【总结】  如何在橙子建站上传落地页?操作指南详解  ChatGPT常用指令模板大全 新手快速上手的万能Prompt合集  Windows10如何更改计算机工作组_Win10系统属性修改Workgroup  湖南网站制作公司,湖南上善若水科技有限公司做什么的?  高性能网站服务器配置指南:安全稳定与高效建站核心方案  PHP 500报错的快速解决方法  Python结构化数据采集_字段抽取解析【教程】  Bootstrap整体框架之JavaScript插件架构  如何用IIS7快速搭建并优化网站站点?  详解Nginx + Tomcat 反向代理 如何在高效的在一台服务器部署多个站点  如何制作公司的网站链接,公司想做一个网站,一般需要花多少钱?  HTML透明颜色代码怎么让图片透明_给img元素加透明色的技巧【方法】  装修招标网站设计制作流程,装修招标流程?  如何快速搭建自助建站会员专属系统?  如何用已有域名快速搭建网站?  文字头像制作网站推荐软件,醒图能自动配文字吗?  Windows Hello人脸识别突然无法使用  海南网站制作公司有哪些,海口网是哪家的?  Laravel用户密码怎么加密_Laravel Hash门面使用教程  Laravel如何实现API资源集合?(Resource Collection教程)  北京网站制作的公司有哪些,北京白云观官方网站?  C++时间戳转换成日期时间的步骤和示例代码  用yum安装MySQLdb模块的步骤方法  如何挑选高效建站主机与优质域名?  Laravel Seeder怎么填充数据_Laravel数据库填充器的使用方法与技巧  香港服务器WordPress建站指南:SEO优化与高效部署策略  Win10如何卸载预装Edge扩展_Win10卸载Edge扩展教程【方法】  Android中AutoCompleteTextView自动提示  Linux系统运维自动化项目教程_Ansible批量管理实战  如何彻底卸载建站之星软件?  香港服务器网站推广:SEO优化与外贸独立站搭建策略  Laravel Pest测试框架怎么用_从PHPUnit转向Pest的Laravel测试教程  Laravel怎么实现前端Toast弹窗提示_Laravel Session闪存数据Flash传递给前端【方法】  如何自己制作一个网站链接,如何制作一个企业网站,建设网站的基本步骤有哪些?  专业企业网站设计制作公司,如何理解商贸企业的统一配送和分销网络建设?  Win11怎么关闭资讯和兴趣_Windows11任务栏设置隐藏小组件  Laravel怎么生成URL_Laravel路由命名与URL生成函数详解  长沙做网站要多少钱,长沙国安网络怎么样?  如何用西部建站助手快速创建专业网站?  使用豆包 AI 辅助进行简单网页 HTML 结构设计  JavaScript中如何操作剪贴板_ClipboardAPI怎么用  如何快速生成可下载的建站源码工具?  Laravel如何为API编写文档_Laravel API文档生成与维护方法  Laravel怎么实现观察者模式Observer_Laravel模型事件监听与解耦开发【指南】