C++实现整数“第二数位”翻转:代码详解与复杂度分析
以下是使用 C++ 语言解决该问题的代码: ```cpp #include <iostream> #include <string> #include <algorithm> using namespace std; int main() { string n; // 读取输入的整数作为字符串 cin >> n; // 如果字符串长度为奇数,在前面补一个 0 if (n.length() % 2 != 0) { n = "0" + n; } string result = ""; // 从字符串末尾开始,每两个字符一组添加到结果字符串中 for (int i = n.length() - 2; i >= 0; i -= 2) { result += n.substr(i, 2); } // 去除结果字符串前面可能存在的 0 int start = 0; while (start < result.length() && result[start] == '0') { start++; } // 如果结果全是 0,输出 0 if (start == result.length()) { cout << "0" << endl; } else { // 输出去除前导 0 后的结果 cout << result.substr(start) << endl; } return 0; } ``` 代码解释 1. 输入处理:将输入的整数作为字符串读取,这样方便处理数位。如果字符串长度为奇数,在前面补一个 0,确保可以每两个字符一组进行处理。 2. 数位翻转:从字符串末尾开始,每两个字符一组添加到结果字符串中,实现「第二数位」的翻转。 3. 去除前导 0:遍历结果字符串,找到第一个不是 0 的字符的位置,然后截取从该位置开始的子字符串。如果结果全是 0,输出 0。 复杂度分析 - 时间复杂度:$O(n)$,其中 $n$ 是输入整数的位数。 - 空间复杂度:$O(n)$,主要用于存储结果字符串。 ######[AI问答 | 462点数解答 | 2025-11-10 20:30:20]
- C语言实现整数“第二数位”翻转:代码详解与复杂度分析(字节豆包 | 523点数解答 | 2025-11-10 19:54:57)84
- C++实现整数“第二数位”翻转:代码详解与复杂度分析(字节豆包 | 462点数解答 | 2025-11-10 20:30:20)106
- 判断超级幸运数:满足“纯4/7数位”或“4/7总个数为4或7”的整数计数(阿里通义 | 965点数解答 | 2026-03-13 12:15:06)20
- Python 实现球类:精准计算半径、表面积与体积,附输入验证与异常处理!(阿里通义 | 261点数解答 | 2024-11-28 21:19:39)343
- 深度揭秘 Oracle Workarea Size Policy:参数调优助力数据库性能飞升(阿里通义 | 372点数解答 | 2024-05-13 10:54:45)226
- C++求解序列或与运算和差值:避O(nq)复杂度及数据处理要点(字节豆包 | 534点数解答 | 2025-10-17 20:05:07)60
- C 语言:按特定顺序读入并输出浮点数、整数和字符(字节豆包 | 106点数解答 | 2024-09-26 00:32:40)310
- C语言:按序读入浮点数、整数、字符并按新顺序输出,附代码实现 (字节豆包 | 108点数解答 | 2024-09-30 22:54:08)327
- C语言:按特定顺序读入并输出浮点数、整数和字符,精确控制小数位(字节豆包 | 155点数解答 | 2024-10-08 22:06:18)321
- C++与Python:按特定顺序输入输出数据并保留浮点数两位小数的实现(字节豆包 | 168点数解答 | 2024-10-08 22:07:03)324
- C语言:按特定顺序读入再输出,含浮点数精确格式处理(字节豆包 | 105点数解答 | 2024-10-08 22:07:29)334
- C++ 混合类型数据格式化输入输出:按指定顺序输出并保留两位小数(字节豆包 | 187点数解答 | 2024-10-16 14:31:08)379