如何统计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取位 + 整除去位”的模式,是解决数字拆分、回文判断、进制转换等基础算法问题的关键基石。
相关栏目:
【
网站优化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模型事件监听与解耦开发【指南】

