【入门】C++ 求解 1~n 范围内数字之和为 13 的整数个数
以下是解决该问题的 C++ 代码: ```cpp #include <iostream> // 计算一个整数各位数字之和的函数 int digitSum(int num) { int sum = 0; // 通过不断取余和整除操作计算各位数字之和 while (num > 0) { sum += num % 10; num /= 10; } return sum; } int main() { int n; std::cin >> n; int count = 0; // 遍历 1 到 n 之间的所有整数 for (int i = 1; i <= n; i++) { // 检查当前数字的各位数字之和是否为 13 if (digitSum(i) == 13) { count++; } } // 输出符合条件的数字的个数 std::cout << count << std::endl; return 0; } ``` ### 代码解释: 1. **`digitSum` 函数**:该函数用于计算一个整数各位数字之和。通过不断取余和整除操作,将每一位数字取出并累加到 `sum` 中,最后返回 `sum`。 2. **`main` 函数**:首先读取输入的整数 `n`,然后使用一个 `for` 循环遍历从 1 到 `n` 的所有整数。对于每个整数,调用 `digitSum` 函数计算其各位数字之和,并检查是否等于 13。如果等于 13,则将计数器 `count` 加 1。最后输出 `count` 的值。 ### 复杂度分析: - **时间复杂度**:$O(n * log_{10}n)$,其中 $n$ 是输入的整数。对于每个整数,需要 $O(log_{10}n)$ 的时间来计算其各位数字之和。 - **空间复杂度**:$O(1)$,只使用了常数级的额外空间。 ######[AI问答 | 483点数解答 | 2026-04-12 15:52:55]
- Python 实现字母与 ASCII 码的灵活转换程序(字节豆包 | 295点数解答 | 2025-11-02 16:58:48)89
- 判断超级幸运数:满足“纯4/7数位”或“4/7总个数为4或7”的整数计数(阿里通义 | 965点数解答 | 2026-03-13 12:15:06)32
- C++ 实现:精准统计给定范围 [L, R] 内数字 2 出现的次数及代码详解(字节豆包 | 401点数解答 | 2026-02-05 21:17:05)49
- C++实现:统计[L, R]范围内数字2出现的次数及代码详解(字节豆包 | 489点数解答 | 2026-02-07 17:12:26)61
- 【入门】C++ 求解 1~n 范围内数字之和为 13 的整数个数(字节豆包 | 483点数解答 | 2026-04-12 15:52:55)4
- 扑克牌比大小游戏结果判断代码实现(字节豆包 | 94点数解答 | 2026-03-29 21:48:15)10
- C++实现扑克牌比大小游戏判断(字节豆包 | 371点数解答 | 2026-03-29 21:49:05)11
- 计算区间 n 到 m 中数字 x 出现次数的 Python 实现与详解(字节豆包 | 289点数解答 | 2025-12-07 17:14:59)86
- Python 实现:计算区间 n 到 m 中数字 x 出现的次数(字节豆包 | 322点数解答 | 2025-12-13 21:37:08)85
- 字符图形:字母正三角的Python实现(字节豆包 | 358点数解答 | 2026-04-02 14:17:17)28
- Python 实现打印字母正三角图形(字节豆包 | 360点数解答 | 2026-04-02 14:17:39)21
- 【入门】C++实现字母正三角字符图形打印(字节豆包 | 323点数解答 | 2026-04-02 14:18:02)16