“水仙花数”是指一个三位数,其各位数字的立方和确好等于该数本身,如;153153?,则153是一个“水仙花数”。在数论中,水仙花数(Narcissistic number)也称为自恋数、自幂数、阿姆斯壮数或阿姆斯特朗数(Armstrong number),是指一N位数,其各个数之N次方和等于该数。

例如153370371407就是三位数的水仙花数,其各个数之立方和等于该数:

153 = 1^3 + 5^3 + 3^3

370 = 3^3 + 7^3 + 0^3

371 = 3^3 + 7^3 + 1^3

407 = 4^3 + 0^3 + 7^3

代码如下:

#include<stdio.h>
int main()
{int num,i,j,k;printf("0到999之间的所有水仙花数:");for(num=100;num<1000;num++){i=num/100;/*求出百位数*/j=num/10-i*10;/*求出十位数*/k=num-i*100-j*10;/*求出个位数*/if(i*i*i+j*j*j+k*k*k==num){printf("%d ",num);}}return 0;
}

上述方法求出一个数的每位数较麻烦,利用for循环对此进行改进。

代码如下:

#include<stdio.h>
#include<math.h>
int main()
{int i;double sum;printf("输出0到999之间的所有水仙花数:\n");for(i=100;i<1000;i++){/*不可在循环体内修改循环变量,防止for循环失去控制*/int num=i;/*引入变量num*/for(sum=0;num!=0;num/=10){  sum+=pow(num%10,3);}if(sum==i)/*sum应与i比较,不是引入的变量num*/{printf("%d ",i);}}return 0;
}