C语言(求0到十万之间的水仙花数)

百度百科:水仙花数(Narcissistic number)也被称为超完全数字不变数(pluperfect digital invariant, PPDI)、自恋数、自幂数、阿姆斯壮数或阿姆斯特朗数(Armstrong number),水仙花数是指一个 3 位数,它的每个位上的数字的 3次幂之和等于它本身。例如:1^3 + 5^3+ 3^3 = 153。
解题思路,我们可以先求出一个数是n位数,之后在将其的个十百。。位利用pow函数进行n次方求和,最后进行比较
源码如下:
#include<stdio.h>
#include<math.h>//使用pow函数时要使用
int main()
{
int i = 0;

for ( i = 0; i <= 100000; i++)
{
	int n = 0;//代表有几位数,比如123,那么n就为3,
	int tem = i;//使用一个临时变量来存放i,用来进行判断等操作,如若不然,会改变i的值,导致死循环
	while (tem)//求n的值,
	{
		n++;
		tem = tem / 10;

	}
	tem = i;//重新赋值,
	int sum = 0;//用于存放个位十位百位n次方的累加和
	while (tem)
	{
		sum += pow(tem % 10, n);
		tem = tem / 10;

	}
	if (sum == i)//判断
	{
		printf("%d\n", i);

	}
	
}
return 0;

}

猜你喜欢

转载自blog.csdn.net/Kirihara_Yukiho/article/details/123159754