C++ 实现:从 1 到 n 统计数字 1 出现次数的高效算法
```cpp #include <iostream> using namespace std; int countDigitOne(int n) { int count = 0; long long factor = 1; // 当前位数(个位、十位、百位...) while (n / factor > 0) { int lower = n % factor; // 低位数字 int cur = (n / factor) % 10; // 当前位数字 int higher = n / (factor * 10); // 高位数字 // 根据当前位数字计算1的个数 if (cur == 0) { count += higher * factor; } else if (cur == 1) { count += higher * factor + lower + 1; } else { count += (higher + 1) * factor; } factor *= 10; // 移动到下一位 } return count; } int main() { int n; cin >> n; cout << countDigitOne(n) << endl; return 0; } ``` 算法思路: 1. 逐位统计数字1出现的次数 2. 将数字分为三部分:高位数字、当前位数字、低位数字 3. 根据当前位数字的值分三种情况计算: - 当前位为0:1的个数 = 高位数字 × 当前位数 - 当前位为1:1的个数 = 高位数字 × 当前位数 + 低位数字 + 1 - 当前位≥2:1的个数 = (高位数字 + 1) × 当前位数 示例说明: 输入:12 输出:5 计算过程: - 个位:高位=1,当前位=2,低位=0 → (1+1)×1=2 - 十位:高位=0,当前位=1,低位=2 → 0×10+2+1=3 - 总计:2+3=5 时间复杂度: O(log₁₀ n) 空间复杂度: O(1) ######[AI问答 | 452点数解答 | 2025-12-20 14:49:52]
- Python 实现球类:精准计算半径、表面积与体积,附输入验证与异常处理!(阿里通义 | 261点数解答 | 2024-11-28 21:19:39)376
- 巴黎奥运:中国女排淘汰赛对决土耳其,朱婷成致胜关键!(字节豆包 | 448点数解答 | 2024-08-06 15:59:48)178
- 51 单片机:定时器 0 实现 8 个 LED 循环点亮,附代码及优化建议(字节豆包 | 1193点数解答 | 2024-12-27 15:10:29)347
- Python切片操作巧解经典算法:二维数组90°旋转(阿里通义 | 205点数解答 | 2023-10-31 11:05:29)350
- 揭秘iOS开发:常用算法大集合,提升应用性能与体验!(阿里通义 | 246点数解答 | 2023-11-08 00:43:08)302
- 深入解析:Vue2.x与Vuex3.x渲染器的Diff算法奥秘(阿里通义 | 222点数解答 | 2023-11-09 01:35:41)379
- 突破 long 范围限制:用 BigInteger 类实现超大数字竖式乘法运算( | 555点数解答 | 2024-03-17 10:56:49)378
- 超范围数字乘法:字符串转数组+模拟竖式运算的实现攻略( | 377点数解答 | 2024-03-17 10:58:21)377
- Java 实现:突破 long 范围限制,模拟竖式运算处理大数字乘法( | 14点数解答 | 2024-03-17 10:58:39)355
- Java实现:突破long范围限制,模拟人工竖式运算大数字乘法( | 1022点数解答 | 2024-03-17 10:59:43)360
- C语言实现:从键盘输入正整数,轻松判断是否为素数(百度文心 | 576点数解答 | 2024-11-10 19:38:17)348
- C 语言:用欧几里得算法从键盘输入两数求最大公约数(附代码及注意点)(字节豆包 | 277点数解答 | 2024-12-31 10:47:11)305