”水仙花数”:是指一个n位数,其各位数字的n次方之和恰好等于该数本身,如:153=13+53+3^3,则153是一个“水仙花数”。
打印水仙花函数
#define _CRT_SECURE_NO_WARNINGS
#include<math.h>
void WaterFlower(int start, int end)//要判断的数范围:起始数start-结束数end
{
int i = 0;
int n = 1; //几位数
int tmp = 0;//计算几位数时的临时变量
int cp = 0; //各位的n次方之和
for (i = start; i <= end; i++)
{
tmp = i;
cp = 0; //与新数比较时,cp清零
n = 1; //与新数比较时,位数n归1
while (tmp/10) //计算几位数
{
n++;
tmp /= 10;
}
tmp = i;
while (tmp)
{
cp+=pow(tmp % 10, n); //计算各位的n次方之和
tmp /= 10;
}
if (cp == i) //如果各位的n次方之和等于i
{
printf("%d ", i);
}
}
}