1.常规法:
#include <stdio.h>
#include <math.h>
int main()
{
int i = 0;
for (i = 0;i <= 10000;i++)
{
//判断i是否为“水仙花数”
//1.计算i是几位数--n
//2.得到i的每一位,计算它的n次方之和
int n = 1;//任何一个数至少是一位数
int tmp = i;//把i的值赋给tmp是为了避免下面的while循环改变i的值
int sum = 0;
while(tmp/10)//一个数除10不是0,位数加1
{
n++;//n接收是几位数
tmp /= 10;
}
tmp = i;
while (tmp)
{
sum += pow(tmp % 10, n);//pow(a,b)库函数,计算a的b次方,引用头文件#include <math.h>
tmp /= 10;
}
if (sum == i)
{
printf("%d ", i);
}
}
return 0;
}
2.函数法:
#include <stdio.h>
#include <math.h>
int is_narcissistic_number(int i)
{
int n = 1;//任何一个数至少是一位数
int tmp = i;//把i的值赋给tmp是为了避免下面的while循环改变i的值
int sum = 0;
while (tmp / 10)//一个数除10不是0,位数加1
{
n++;//n接收是几位数
tmp /= 10;
}
tmp = i;
while (tmp)
{
sum += pow(tmp % 10, n);//pow(a,b)库函数,计算a的b次方,引用头文件#include <math.h>
tmp /= 10;
}
if (sum == i)
{
return 1;
}
else
return 0;
}
int main()
{
int i = 0;
for (i = 0;i <= 10000;i++)
{
if (is_narcissistic_number(i))
{
printf("%d ", i);
}
}
return 0;
}
3.稍稍简化一小下:
#include <stdio.h>
#include <math.h>
int is_narcissistic_number(int i)
{
int n = 1;//任何一个数至少是一位数
int tmp = i;//把i的值赋给tmp是为了避免下面的while循环改变i的值
int sum = 0;
while (tmp / 10)//一个数除10不是0,位数加1
{
n++;//n接收是几位数
tmp /= 10;
}
tmp = i;
while (tmp)
{
sum += pow(tmp % 10, n);//pow(a,b)库函数,计算a的b次方,引用头文件#include <math.h>
tmp /= 10;
}
return sum == i;
}
int main()
{
int i = 0;
for (i = 0;i <= 10000;i++)
{
if (is_narcissistic_number(i))
{
printf("%d ", i);
}
}
return 0;
}