C语言:输出“水仙花数”

题目:输出100到1000的水仙花数。

背景:水仙花数是指一个 3 位数,它的每个位上的数字的 3次幂之和等于它本身

            1^3 + 5^3+ 3^3 = 153

思路:采用 for 循环,利用数学知识。

代码:

//5.水仙花数(在100-1000中的水仙花数)
#include<stdio.h>
#include<math.h> //引用数学的头文件
int main()
{
	int i = 100;
	int ge_wei = 0; //初始化,个位
	int shi_wei = 0;//初始化,十位
	int bai_wei = 0;//初始化,百位
	for (i = 100; i <= 1000; i++)
	{
		ge_wei = i % 10;          //求出个位
		shi_wei = (i / 10) % 10;  //求出十位
		bai_wei = (i / 100) % 10; //求出百位
		//判断
		if (i == pow(ge_wei, 3) + pow(shi_wei, 3) + pow(bai_wei, 3))
		{
			printf("%d ", i);
		}
	}
	return 0;
}

细节:pow( x , y )是求次方,为 x 的 y 次方。

猜你喜欢

转载自blog.csdn.net/AAlykk/article/details/130675400