学习了那么久,大家知道什么是“水仙花数”嘛?
水仙花数:?
????????是指一个三位数,其各位数字的立方和等于该数本身。
????????例如:153是一个水仙花数,因为153=++。
解题思路:
1. “水仙花数”是三位数,所以水仙花数 n 满足:99 < n <1000,我们选用穷举法来逐一判断;
2. “水仙花数”满足:其各位数字的立方和等于该数本身。
? ? ? ? 所以,本题的关键点在于:如何分离各位上的数字。
3. 分离各位上的数字:
? ? ? ? 分解个位:a = n/100;
????????分解十位:b = n/10%10;
????????分解百位:c = n%100%100;
4. 整体代码为:
#include<stdio.h>
int main()
{
int a, b, c, i;
for(i=100;i<=999;i++)
{
a=i/100;\\分解个位
b=i/10%10;\\分解十位
c=i%100%10;\\分解百位
if(i==a*a*a+b*b*b+c*c*c)\\判断是否为“水仙花数”
printf("%d\n",i);
}
return 0;
}
?5.运行结果为:
?
怎么样?
学会如何打印“水仙花数”了嘛?
如果有用,请点点赞哦 !
欢迎一键三连哦。