所谓“水仙花数”是指一个三位数,其各位数字立方和等于该数 本身。
例如:153是一个“水仙花数”,因为153=1的三次方+5的三次方+3的三次方。
题目:
找出100-999之间的所有水仙花数,每一列输出一个。
思路:
个位的立方+十位的立方+百位的立方=一个三位数
已知一个三位数n,它的百位数字i即n/100(“/”符号表示前面的数字除以后面的数字之后取整数部分),十位数字j即(n-i*100)/10,个位数字t即n-i*100-j*10
代码:
#include "stdio.h"
int main()
{
int i, j, t, n;
printf("100-999之间的水仙花数有:\n");
for (n = 100; n <= 999; n++)
{
{
i = n / 100;
j = (n - i * 100) / 10;
t = n - i * 100 - j * 10;
}
{
if (n == i * i*i + j * j*j + t * t*t)
printf("%d\n", n);
}
}
return 0;
}
运行结果: