这个题我在昨天晚上写的时候,发现了很多种解法,现在分享一下自己的思路来给需要的人。
1.利用int类型直接取整来求出目标数(从四位数的前面往后面开始读取)
#include<stdio.h>//
int main()//将一个四位数,反向输出。
{
int a, b, c, d, e;
scanf_s("%d", &a);
b = int(a / 1000);//1
c = int((a - b * 1000) / 100);
d = int((a - b * 1000 - c * 100) / 10);
e = int((a - b * 1000 - c * 100 - d * 10));
//printf("%d", e*1000+d*100+c*10+b);//输出的是一个整数
printf("%d%d%d%d", e,d,c,b);
return 0;
}
我的思路是首先设置四个数来分别取万位,千位,百位,个位。
就用取c,也就是取千位来说,用万位来减去原来的数,然后嘞个数成为一个三位数然后用/求出千位,后面也同理。
但是这个过程写的太离谱了,走了很多弯路,而且我昨天在VS2019可以运行成功但是在牛客网上不可以。因此我换了第二种方法。
2.利用求余数来算(从四位数的后面开始往前面读取)
#include<stdio.h>
int main()//将一个四位数,反向输出。
{
int a, b, c, d, e;
scanf_s("%d", &a);
b = a % 10;//个位
c = (a / 10) % 10;//十位
d = (a / 100) % 10;//百位
e = (a / 1000) % 10;//千位
printf("%d%d%d%d", b,c,d,e);
// int n;//for循环来求
/* scanf_s("%d", &n);
for (int i = 0; i < 4; i++)
{
printf("%d", n % 10);
n /= 10;
}*/
return 0;
}
这个代码就显得简单了很多,也更好的理解
我来解释一下子,从取万位开始直接用%取余,然后千位先把四位数变为三位数(从后往前推)然后后面同理
这个代码也可以简化成一个for循环来解决,我也标记出来了,这样做更简单更方便。
最后运行一下代码
成功运行!
感谢阅读