水仙花数是指一个N位正整数(N≥3),它的每个位上的数字的N次幂之和等于它本身。 本题要求编写程序,计算所有N位水仙花数。
输入格式:
输入在一行中给出一个正整数N(3≤N≤7)。
输出格式:
按递增顺序输出所有N位水仙花数,每个数字占一行。
输入样例:
3
输出样例:
153
370
371
407
- 将各位数字取出,并进行求和。若相等则证明是水仙花数返回该数本身,否则返回0
int narcissistic(int num)
{
int sum = 0;
int n = num;//这里不能只能直接用num进行分解,要先把num的值保存下来。因为如果直接用num分解,则最后num的值为0,无法进行与sum值的比较
while (n > 0)
{
int d = n % 10;
sum = sum +p[d];
n /= 10;
}
if (sum == num)
{
return num;
}
else
{
return 0;
}
}
2.将符合要求的数字依次输出
void Print(int m,int n)
{
int num = m;
for (num; num < n; num++)
{
int ret = narcissistic(num);
if (ret != 0)
{
printf("%d\n", ret);
}
}
}
- 依次将数字进行累加,从m到n
int main()
{
int num = 0;
int N = 0;
scanf("%d", &N);
//因为每一位的数字范围都是0-9,所以把0-9的次幂值都存入数组中,后面计算各个位的次幂加和时可以直接根据取下的各个位找到对应数组的值进行加和,避免了多次调用pow函数
for (int i = 0; i < 10; i++)
{
p[i] = pow(i, N);
}
Print(pow(10, N - 1), pow(10, N));
return 0;
}
- 完整代码
#include <stdio.h>
#include<math.h>
int p[20]={0};
int narcissistic(int num)
{
int sum = 0;
int n = num;//这里不能只能直接用num进行分解,要先把num的值保存下来。因为如果直接用num分解,则最后num的值为0,无法进行与sum值的比较
while (n > 0)
{
int d = n % 10;
sum = sum +p[d];
n /= 10;
}
if (sum == num)
{
return num;
}
else
{
return 0;
}
}
void Print(int m,int n)
{
int num = m;//从M开始记录并不算N
for (num; num < n; num++)
{
int ret = narcissistic(num);
if (ret != 0)
{
printf("%d\n", ret);
}
}
}
int main()
{
int num = 0;
int N = 0;
scanf("%d", &N);
//因为每一位的数字范围都是0-9,所以把0-9的次幂值都存入数组中,后面计算各个位的次幂加和时可以直接根据取下的各个位找到对应数组的值进行加和,避免了多次调用pow函数
for (int i = 0; i < 10; i++)
{
p[i] = pow(i, N);
}
Print(pow(10, N - 1), pow(10, N));//本程序要求输出N位数字的水仙花数
return 0;
}