用C语言程序实现求水仙花数。
首先,什么是水仙花数呢?
根据百度百科定义,水仙花数只是自幂数的一种,严格来说3位数的3次幂数才称为水仙花数。也被称为超完全数字不变数(pluperfect digital invariant, PPDI)、自恋数、自幂数、阿姆斯壮数或阿姆斯特朗数(Armstrong number),水仙花数是指一个 3 位数,它的每个位上的数字的 3次幂之和等于它本身。
例如:1^3 + 5^3+ 3^3 = 153
根据以上我们可以知道,水仙花数是一个三位数其各位数字的立方和等于该数本身的数字。
那我们如何来实现呢?
水仙花数是一个三位数,可以确定该数的取值范围是 100〜999。把给出的某个三位数的个位、十位、百位分别拆分,并求其立方和(设为sum),若sum与给出的三位数相等, 则为水仙花数。
具体实现如下:
#include "stdio.h"
void main()
{
int a,b,c;
int i =100;
while( i < 1000)
{
//个位 十位 百位
a = i % 10;
b = i / 10 % 10;
c = i / 100;
if(i == a*a*a+b*b*b+c*c*c) //水仙花数
{
printf("%d \n",i);
}
i++;
}
}
得到如下结果: