百度百科:水仙花数(Narcissistic number)也被称为超完全数字不变数(pluperfect digital invariant, PPDI)、自恋数、自幂数、阿姆斯壮数或阿姆斯特朗数(Armstrong number),水仙花数是指一个 3 位数,它的每个位上的数字的 3次幂之和等于它本身。例如:1^3 + 5^3+ 3^3 = 153。
解题思路,我们可以先求出一个数是n位数,之后在将其的个十百。。位利用pow函数进行n次方求和,最后进行比较
源码如下:
#include<stdio.h>
#include<math.h>//使用pow函数时要使用
int main()
{
int i = 0;
for ( i = 0; i <= 100000; i++)
{
int n = 0;//代表有几位数,比如123,那么n就为3,
int tem = i;//使用一个临时变量来存放i,用来进行判断等操作,如若不然,会改变i的值,导致死循环
while (tem)//求n的值,
{
n++;
tem = tem / 10;
}
tem = i;//重新赋值,
int sum = 0;//用于存放个位十位百位n次方的累加和
while (tem)
{
sum += pow(tem % 10, n);
tem = tem / 10;
}
if (sum == i)//判断
{
printf("%d\n", i);
}
}
return 0;
}