采用for循环,用穷举法思想求解。打印出所有“水仙花数”,所谓“水仙花数”,指的是一个三位数,其各位数字的立方和等于该数本身。例如:153=13+53+33。
此处我们将用穷举法求解。即三位数x从100-999循环试探,如果满足“水仙花数”条件,那么此时的x就是一个解。重点思考如何将三位数分解成百位、十位、个位。
运行代码如下所示:
#include<stdio.h>
void main()
{
int a,b,c,n;
printf("3位数以内的水仙数为:\n");
for(n=100;n<=999;n++) //这里是让n在三位数以内
{
a=n/100; //分解出个位
b=n/10%10; //分解出十位
c=n%100%10;//分解出百位
if(n==a*a*a + b*b*b + c*c*c)
printf("%d\n",n);//判断该数的各位数字的立方和是否等于该数本身(即水仙花数)
}
}
运行结果如下图所示: