酷代码 AI
菜单
服务商

题目描述 十进制数字中的每一个数码可以用数位来描述。例如,503 的个位为 3,十位为 0,百位为 5。对其进行数位翻转,就是将最高位变为最低位,而最低位变为最高位。503 翻转后的结果为 305。 小 A 定义了「第二数位」。十进制数从低位到高位,每两个数码构成一个「第二数位」,最高位不足两个数码的,用前导零补齐。例如,12345 将被划分为 01​ 23​ 45​,共三个「第二数位」。 类似的,「第二数位」翻转,就是将最高位的「第二数位」变为最低位的「第二数位」,而最低位的「第二数位」变为最高位的「第二数位」。「第二数位」内的数码顺序不变。 给出整数 n,请对其进行「第二数位」翻转。翻转后输出的十进制整数不应包含前导零。 输入格式 一行一个整数 n 输出格式 输出一行一个整数,表示对 n 「第二数位」翻转后的结果。 输入样例1 123456 输出样例1 563412 用c语言

```c #include <stdio.h> #include <string.h> #define MAX_LEN 100 int main() { // 定义字符数组用于存储输入的数字 char num[MAX_LEN]; // 存储处理后的数字 char result[MAX_LEN] = {0}; // 输入数字并存储到 num 数组中 scanf("%s", num); int len = strlen(num); // 如果长度为奇数,添加前导零 if (len % 2 != 0) { for (int i = len; i > 0; i--) { num[i] = num[i - 1]; } num[0] = '0'; len++; } int index = 0; // 进行第二数位翻转 for (int i = len - 2; i >= 0; i -= 2) { result[index++] = num[i]; result[index++] = num[i + 1]; } // 去除前导零 int start = 0; while (result[start] == '0' && result[start + 1] != '\0') { start++; } // 输出结果 printf("%s\n", result + start); return 0; } ``` 代码解释 1. 输入处理:使用 `scanf` 读取输入的整数,并将其存储在字符数组 `num` 中。 2. 补齐长度:检查输入数字的长度,如果长度为奇数,在最前面添加一个前导零,确保长度为偶数,方便后续按两个数码一组处理。 3. 第二数位翻转:从后往前遍历 `num` 数组,每次取两个数码,依次存到 `result` 数组中,实现第二数位的翻转。 4. 去除前导零:遍历 `result` 数组,跳过前导零,直到遇到非零数字或者到达数组末尾。 5. 输出结果:输出去除前导零后的 `result` 数组。 复杂度分析 - 时间复杂度:$O(n)$,其中 $n$ 是输入数字的长度。 - 空间复杂度:$O(n)$,主要用于存储输入和处理后的数字。 [2025-11-10 19:54:57 | AI问答 | 523点数解答]

相关提问
发财导航,免费问AI
实用工具查看更多