解题思路:
注意事项:
参考代码:
#include "stdio.h"
#include "math.h"
int J(int n) //求阶乘
{
if (n == 1||n==0)return 1;
int num;
num = n * J(n - 1);
return num;
}
int X(int m) //求每一位阶乘和
{
int sum=0,q1;
while (1)
{
q1 = m % 10;
sum += J(q1);
m = m / 10;
if (m == 0)break;
}
return sum;
}
int main()
{
for (int i = 1; i <= 9; i++)//排序输出
{
int num = i; int k = 0;
while (num <= 100000)
{
for (int j = num; j < num+pow(10,k); j++)
{
if (j == X(j))printf("%d ", j);
}
num *= 10;
k++;
}
}
}
0.0分
0 人评分