“水仙花数”是指一个三位数,其各位数字的立方和确好等于该数本身,如;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;
}