求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。