”水仙花数“只是自幂数的一种,严格来说3位数的3次幂数才称为水仙花数。例如:153是一个水仙花数,因为153=1^3+5^3+3^3。
附:其他位数的自幂数名字
一位自幂数:独身数
三位自幂数:水仙花数
四位自幂数:四叶玫瑰数
五位自幂数:五角星数
六位自幂数:六合数
七位自幕数:北斗七星数
基于此,我们可以用for循环得到0~~100000的数字,求出该数是几位数,然后求出其每位数的几次幂及它们的和,再判断它们的和是否与该数相等。
用上图函数求出该数是几位数。
在求每位数的几次幂及它们的和之前,先认识一个函数----pow函数,它的功能是计算x的y次幂,返回幂指数的结果,头文件为<math.h>。例如:
上面图1已经求出该数是几位数,现在再设计一个函数求出各位位数的几次幂的和就可以了。如下图:
如何打印0~~100000的水仙花数的基本逻辑上述已经都说明了,OK,下面就是整体打印0~~100000的代码:
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<math.h>
int Funct(int m)
{
int count = 0;
while (m)
{
m /= 10;
count++;
}
return count;
}
double Sum(int x, int y)
{
double sum = 0;
while (x)
{
sum += pow(x%10, y);
x /= 10;
}
return sum;
}
int main()
{
int n = 0;
for(n=0;n<=100000;n++)
{
double z = Sum(n,Funct(n));
if (z == n)
printf("%d ", n);
}
printf("\n");
return 0;
}