这个题我在昨天晚上写的时候,发现了很多种解法,现在分享一下自己的思路来给需要的人。
1.利用int类型直接取整来求出目标数(从四位数的前面往后面开始读取)
#include// 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.利用求余数来算(从四位数的后面开始往前面读取)
#includeint 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循环来求 return 0; }
这个代码就显得简单了很多,也更好的理解
我来解释一下子,从取万位开始直接用%取余,然后千位先把四位数变为三位数(从后往前推)然后后面同理
这个代码也可以简化成一个for循环来解决,我也标记出来了,这样做更简单更方便。
最后运行一下代码
成功运行!
感谢阅读
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)