判断水仙花数

水仙花数(Narcissistic number)也被称为超完全数字不变数(pluperfect digital invariant, PPDI)、自恋数、自幂数、阿姆斯壮数或阿姆斯特朗数(Armstrong number),水仙花数是指一个 3 位数,它的每个位上的数字的 3次幂之和等于它本身。例如:1^3 + 5^3+ 3^3 = 153。

常见水仙花数

水仙花数又称阿姆斯特朗数

三位的水仙花数共有4个:153,370,371,407;

四位的四叶玫瑰数共有3个:1634,8208,9474;

五位的五角星数共有3个:54748,92727,93084;

六位的六合数只有1个:548834;

七位的北斗七星数共有4个:1741725,4210818,9800817,9926315;

八位的八仙数共有3个:24678050,24678051,88593477;

九位的九九重阳数共有4个: 146511208,472335975,534494836,912985153;

十位的自幂数只有1个:4679307774

常见的水仙花数有这些,但是我们是如何用代码来判断水仙花数,所以接下来我来给大家详细讲解一下吧!!!

int main()
{
	int i = 0;
	for (i = 0; i <= 100000; i++)//找100000之内的水仙花数
	{
		//判断i是否为水仙花数
		//1.计算i的位数   n位数//因为后面要用次方,次方是位数个数
		int n = 1;//位数个数最低为1
		int tmp = i;//在循环中i的值会发生改变,为了防止这一情况,要另附一个值
		int sum = 0;
		while (tmp /= 10)
		{
			n++;
		}
		//2.计算i的每一次的n次方之和sum
		tmp = i;
		while (tmp)
		{
			sum += pow(tmp % 10, n);//为一个库函数后面是次方,前面是底数
			tmp /= 10;
		}
		//3.比较i == sim
		if (i == sum)
		{
			printf("%d", i);
		}
	}
	return 0;
}

上面的代码每行都有十分详细的讲解,现在我再给大家举个列子,让大家更加透彻的理解。

以最典型的153为列:

 对此,我把水仙花数的判断方法以及列子给大家做了详细阐明,希望大家可以有所收获,谢谢大家,今天的分享到这结束了,如果大家有任何不明白的,随时可以评论,本人一定会及时做出回复!!!

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值