C语言--打印出所有的水仙花数

   采用for循环,用穷举法思想求解。打印出所有“水仙花数”,所谓“水仙花数”,指的是一个三位数,其各位数字的立方和等于该数本身。例如:153=13+53+33。

   此处我们将用穷举法求解。即三位数x从100-999循环试探,如果满足“水仙花数”条件,那么此时的x就是一个解。重点思考如何将三位数分解成百位、十位、个位。

运行代码如下所示:

#include
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);//判断该数的各位数字的立方和是否等于该数本身(即水仙花数)
	}
}

运行结果如下图所示:

C语言--打印出所有的水仙花数_第1张图片

 

你可能感兴趣的:(笔记,c语言,开发语言,后端)