天天看點

求1000以内的所有水仙花數

求1000以内的所有水仙花數

#include<stdio.h>//列印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<stdio.h>//列印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