C语言实现自幂数

 代码实现:  

#include<stdio.h>
#include<math.h>

int main()
{
	//1.计算i位数-n
	int i = 0;
	for (i = 0; i < 100000; i++)
	{
		int tmp = i;
		int n = 1; //位数不可能为0,最小是1位
		while (tmp /= 10)
		{
			n++;
		}

		//2.计算每一位次方之和

		tmp = i;//这里需要重新赋值

		int sum = 0;//次方之和
		while (tmp)
		{
			sum += pow(tmp % 10,n);//pow库函数-求次方;返回类型为double类型
			tmp /= 10;             //这里的值传过来之后,在进行+=的时候,会进行类型转换
			                       //或者可以强制转换成int类型
		}

		//3.比较
		if (sum == i)
		{
			printf("%d ", i);
		}
	}
	return 0;
}

补充:

    如果在一个固定的进制中,一个n位自然数等于自身各个数位上数字的n次幂之和,则称此数为自幂数。

各种自幂数的名称:

一位自幂数:独身数

两位自幂数:没有

三位自幂数:水仙花数

四位自幂数:四叶玫瑰数

五位自幂数:五角星数

六位自幂数:六合数

七位自幂数:北斗七星数

八位自幂数:八仙数

九位自幂数:九九重阳数

十位自幂数:十全十美数

独身数共有9个: 1,2,3,4,5,6,7,8,9;

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

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

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

六合数只有1个:548834;

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

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

……

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值