C语言:输入一个不多于5位的正整数,要求1:求出它是几位数; 要求2:分别打印出每一位数; 要求3:按逆序打印出各位数字;
时间: 2023-05-23 15:03:21 浏览: 146
ChitGPT: 以下是 C 语言的代码,可以实现您的需求:
```c
#include <stdio.h>
int main() {
int num, digit, count = 0;
int digits[5];
printf("请输入一个不多于5位的正整数:");
scanf("%d", &num);
while (num) {
digit = num % 10; // 取出最低位的数字
digits[count++] = digit; // 将每一位数字存储到数组中
num /= 10; // 将输入数字除以10,获得更高位的数字
}
printf("该数字有 %d 位\n", count);
printf("各位数字分别为:");
for (int i = count - 1; i >= 0; i--) {
printf("%d ", digits[i]);
}
printf("\n按逆序打印各位数字为:");
for (int i = 0; i < count; i++) {
printf("%d ", digits[i]);
}
printf("\n");
return 0;
}
```
希望以上代码可以帮到您!
相关问题
C语言:给一个不多于5位的正整数求它是几位数并逆序打印出各位数字。
```c
#include <stdio.h>
int main() {
int num, count = 0;
int digits[5] = {0}; // 用数组存储每一位数字
printf("请输入一个不多于5位的正整数:");
scanf("%d", &num);
// 分解每一位数字并存储
while (num > 0) {
digits[count++] = num % 10;
num /= 10;
}
printf("该数是%d位数,逆序打印出各位数字为:", count);
for (int i = 0; i < count; i++) {
printf("%d", digits[i]);
}
printf("\n");
return 0;
}
```
运行结果:
```
请输入一个不多于5位的正整数:12345
该数是5位数,逆序打印出各位数字为:54321
```
c语言输入一个不多于5位的正整数, 要求: ①求出它是几位数; 高分别打印出每一位数字; 按逆序打印出各位数字。
在C语言中,你可以通过遍历输入的字符串并处理每个字符来完成这个任务。首先获取输入的字符串,然后确定它的长度(即位数),接着逐个提取每位数字并进行相应的操作。以下是实现该功能的一个示例代码:
```c
#include <stdio.h>
#include <string.h>
void print_digits(int num) {
while (num != 0) {
printf("%d", num % 10); // 打印当前位数字
num /= 10; // 移除最低位数字
}
}
void reverse_print_digits(int num) {
char digits[6]; // 用于存储最多5位数的数组
int i = 0;
while (num > 0) {
digits[i++] = num % 10 + '0'; // 把数字转换成字符并存入数组
num /= 10;
}
digits[i] = '\0'; // 添加终止符
printf("逆序打印: ");
for (i = strlen(digits) - 1; i >= 0; i--) {
printf("%c", digits[i]);
}
printf("\n");
}
int main() {
char input[6];
int number;
printf("请输入一个不超过5位的正整数: ");
fgets(input, sizeof(input), stdin); // 防止读取换行符
input[strcspn(input, "\n")] = '\0'; // 去掉字符串尾部的换行符
number = atoi(input); // 将字符串转为整数
if (number <= 0 || number >= pow(10, 5)) {
printf("输入错误!请输入1到99999之间的正整数。\n");
} else {
printf("位数: %d\n", static_cast<int>(strlen(input) - 1)); // 减去开头的空格
print_digits(number); // 正序打印
reverse_print_digits(number); // 逆序打印
}
return 0;
}
阅读全文
相关推荐













