求出0~999之间的所有“水仙花数”并输出。

在数论中,水仙花数(Narcissistic number)也称为自恋数、自幂数、阿姆斯壮数或阿姆斯特朗数(Armstrong number),是指一N位数,其各个数之N次方和等于该数。
例如153、370、371及407就是三位数的水仙花数,其各个数之立方和等于该数:
153 = 1^3 + 5^3 + 3^3。
370 = 3^3 + 7^3 + 0^3。
371 = 3^3 + 7^3 + 1^3。
407 = 4^3 + 0^3 + 7^3
此程序要运用到math函数库的pow()函数。
也可以不用,直接把各个数相乘三次。
以下是代码。

#define _CRT_SECURE_NO_WARNINGS 1
#include
#include
#include
int main()
{
	int q = 0, w = 0, e = 0;
	for (int i = 0; i <= 999; i++)
	{
		q = i % 10;
		w = i / 10 % 10;
		e = i / 100 % 10;
		if (i == pow(q, 3) + pow(w, 3) + pow(e, 3)&& e != 0)
		{
			printf("%d = %d^3+ %d^3+ %d^3\n", i,q,w,e);
		}
	}
}

你可能感兴趣的:(求出0~999之间的所有“水仙花数”并输出。)