解密2025数字密码:数位统计之谜

#include <stdio.h>
int check(int n)
{
int c0 = 0;
int c2 = 0;
int c5 = 0;
while(n > 0)
{
int d = n % 10;
if(d == 0) c0 ++;
if(d == 2) c2 ++;
if(d == 5) c5 ++;
n /= 10;
}
if(c0 >= 1 && c2 >=2 && c5 >= 1) return 1;
return 0;
}
int main()
{
int n = 20250412;
int ans = 0;
for(int i = 1;i<=n;i++)
{
if(check(i)) ans ++;
}
printf("%d\n",ans);
return 0;
}

这段代码是在解决一个数位统计问题。简单来说,它的任务是找出 1 到 20250412 之间,所有包含"至少一个 0、两个 2、一个 5"的数字,并统计它们的总数量。

🎯 核心目标与逻辑

这段代码的数学逻辑基于题目提示:

一个数如果能通过重新排列得到"2025",那么它必须包含组成"2025"的所有原材料,即:

  • 至少 1 个数字 0
  • 至少 2 个数字 2
  • 至少 1 个数字 5

⚙️ 函数模块:check(int n)

这个函数是代码的"质检员",负责检查每一个数字是否合格。

详细解析:

  • 初始化 :每次检查新数字时,计数器**c0c2c5** 都必须从 0 开始。
  • while(n > 0):这是一个经典的数位拆解算法
    • 假设输入 n = 2025
    • 第 1 轮:d 是 5,c5 变为 1,n 变为 202。
    • 第 2 轮:d 是 2,c2 变为 1,n 变为 20。
    • 第 3 轮:d 是 0,c0 变为 1,n 变为 2。
    • 第 4 轮:d 是 2,c2 变为 2,n 变为 0(循环结束)。
  • 判定 :最后检查 c0 是否 ≥1≥1 ,c2 是否 ≥2≥2 ,c5 是否 ≥1≥1 。只有全满足才返回 1。

🔄 主程序模块:main()

主函数负责"流水线"工作:遍历所有数字,并调用 check 函数进行筛选。

详细解析:

  • for(int i = 1; i <= n; i++)
    • 这是一个暴力穷举法。程序会从 1 开始,一个一个地数,直到 20250412。
    • 注意 :这里的循环次数超过 2000 万次
  • if(check(i))
    • 程序把当前的数字 i 扔进 check 函数里"过安检"。
    • 如果 check 返回 1(代表合格),ans 就加 1。
    • 如果 check 返回 0(代表不合格),什么都不做,继续检查下一个数。

📌 总结

这段代码就是一个**"暴力筛选器"**:它不玩任何数学捷径,而是老老实实地把 1 到 20250412 之间的每一个数都拆开来看,数一数里面有几个 0、2、5,符合要求的就留下来计数。

相关推荐
csdn_aspnet10 分钟前
Java 霍尔分区算法(Hoare‘s Partition Algorithm)
java·开发语言·算法
诸葛务农18 分钟前
道路行驶条件下电动汽车永磁电机的有效使用寿命及永磁体的失效和回收再利用(下)
java·开发语言·算法
snow@li18 分钟前
AI:理解 大数据、算法、算力、电力、生成式AI、token 之间的关系
大数据·人工智能·算法
小智老师PMP1 小时前
零基础能不能考PMP?零基础专属学习路径+全套扶持体系
学习·算法·职场和发展·软件工程·求职招聘·敏捷流程
Dillon Dong1 小时前
【风电控制】FPGA采集Vdc的ADC增益系数解析——从数字码到实际电压的桥梁
算法·fpga开发·变流器·风电控制
TDengine (老段)1 小时前
TDengine 压缩编码机制 — 双层压缩架构与类型特化算法
大数据·数据库·物联网·算法·时序数据库·tdengine·涛思数据
不会就选b1 小时前
数据结构之顺序表和链表的OJ题(上)
数据结构·链表
妄想出头的工业炼药师2 小时前
LVIO鲁棒
算法·开源
aini_lovee2 小时前
MATLAB 图像修复 — 偏微分方程方法
算法
Cthy_hy2 小时前
Python算法竞赛:排列组合核心用法
开发语言·python·算法