C++ 实现跳过含 4 或 4 的倍数数字从 1 数到 n
以下是一个用 C++ 编写的程序,用于从 1 数到 `n`,同时跳过桃子的倒霉数字(4 的倍数或者包含 4 的数字)。 ```cpp #include <iostream> // 检查一个数是否包含数字 4 bool containsFour(int num) { while (num > 0) { if (num % 10 == 4) { return true; } num /= 10; } return false; } // 主函数 int main() { int n; std::cout << "请输入一个正整数 n: "; std::cin >> n; // 从 1 到 n 进行遍历 for (int i = 1; i <= n; i++) { // 检查是否是 4 的倍数或者包含数字 4 if (i % 4 == 0 || containsFour(i)) { continue; } std::cout << i << std::endl; } return 0; } ``` ### 代码解释 1. **`containsFour` 函数**: - 该函数用于检查一个整数是否包含数字 4。 - 通过不断取该数的最后一位数字,检查是否为 4,如果是则返回 `true`。 - 然后将该数除以 10,去掉最后一位数字,继续检查。 - 如果遍历完所有位都没有找到 4,则返回 `false`。 2. **`main` 函数**: - 首先,程序会提示用户输入一个正整数 `n`。 - 然后,使用 `for` 循环从 1 到 `n` 进行遍历。 - 对于每个数字,使用 `if` 语句检查它是否是 4 的倍数或者包含数字 4。如果是,则使用 `continue` 语句跳过该数字。 - 如果不是倒霉数字,则将其输出。 ### 复杂度分析 - **时间复杂度**:$O(n log_{10} n)$,其中 $n$ 是用户输入的数字。对于每个数字,需要 $O(log_{10} n)$ 的时间来检查是否包含数字 4。 - **空间复杂度**:$O(1)$,只使用了常数级的额外空间。 ######[AI问答 | 563点数解答 | 2026-03-21 19:55:23]
- C++ 实现:精准统计给定范围 [L, R] 内数字 2 出现的次数及代码详解(字节豆包 | 401点数解答 | 2026-02-05 21:17:05)36
- C++实现:统计[L, R]范围内数字2出现的次数及代码详解(字节豆包 | 489点数解答 | 2026-02-07 17:12:26)41
- Python 实现球类:精准计算半径、表面积与体积,附输入验证与异常处理!(阿里通义 | 261点数解答 | 2024-11-28 21:19:39)343
- Python:用正则表达式从含多种字符的字符串中提取英文、数字和中文单词(GPT | 522点数解答 | 2024-05-31 19:05:27)313
- Python:用正则表达式结合 split 思路提取一行字符串中的英文、数字和中文单词 (GPT | 399点数解答 | 2024-05-31 19:07:31)310
- 繁体字编码代码修改:人物名字合法性验证函数转简体版(字节豆包 | 325点数解答 | 2024-10-21 18:57:01)285
- 计算区间 n 到 m 中数字 x 出现次数的 Python 实现与详解(字节豆包 | 289点数解答 | 2025-12-07 17:14:59)71
- Python 实现:计算区间 n 到 m 中数字 x 出现的次数(字节豆包 | 322点数解答 | 2025-12-13 21:37:08)74
- 51 单片机:定时器 0 实现 8 个 LED 循环点亮,附代码及优化建议(字节豆包 | 1193点数解答 | 2024-12-27 15:10:29)310
- DBA必看:MySQL字符转HEX数字的方法与示例(百度文心 | 757点数解答 | 2023-11-09 18:06:01)198
- Excel 日期格式显示####?这些解决办法快收好!( | 327点数解答 | 2023-12-29 09:53:45)280
- Python 编程:轻松统计输入字符中字母、数字、空格及其他字符个数(字节豆包 | 239点数解答 | 2024-10-26 20:53:28)200