求1000以内的所有水仙花数

求1000以内的所有水仙花数

#include//打印1000以内所有的水仙花数
int main()
{
	int i,baiwei=0,shiwei=0,gewei=0;
	for(i=1;i<1000;i++)
	{
 		//printf("本次运算的是%d\n",i);
		baiwei=i/100;
 		shiwei=(i-baiwei*100)/10;
 		gewei=i-baiwei*100-shiwei*10;
 		//printf("%d,%d,%d\n",baiwei,shiwei,gewei);
 		if(i==baiwei*baiwei*baiwei+shiwei*shiwei*shiwei+gewei*gewei*gewei)printf("%d是水仙花数。\n",i);
	}
	return 0;
}
1,153,370,371,407。

在网上看到另一种解法很受启发:

#include//打印1000以内的所有水仙花数
int main()
{
	int x,y,z;//x为百位数字,y为十位数字,z为个位数字
	for(x=0;x<=9;x++)
	{
		for(y=0;y<=9;y++)
		{
			for(z=0;z<=9;z++)
			{
				if((x*100+y*10+z)==(x*x*x+y*y*y+z*z*z))
				printf("%d是水仙花数。\n",(x*100+y*10+z));
			}
		}
	}
	return 0;
}
0,1,153,370,371,407。

你可能感兴趣的:(C)