新手的方法
自增,判断,储存,该位,输出
```c
#include#include"math.h"
int act(int x) {//求阶乘
int y = 0;
if (x == 0 || x == 1)return 1;
else y=act(x - 1)* x;
return y;
}
int fun(int i) {//求位数
int sum = 0;
while (i != 0) {
i /= 10;
sum++;
}
return sum;
}
int main()
{
int x = 0, a[100000],b[100][2],z=0;
for (int k=1; k <= 100000; k++) {
x = fun(k);
int i = k,y=0;
for (int j = 0;j < x; j++) {
a[j] = i % 10;
i /= 10;
}
for (int j = 0; j < x; j++)
y += act(a[j]);
if (y == k) {
b[z][0] = y;
b[z++][1] = x;//保存位数
}
}
for (int i = 0; i < z; i++)//要求开头1,2。。。。输出
for (int j = i + 1; j < z;j++) {
if (b[i][0] / pow(10, b[i][1]-1)> b[j][0] / pow(10, b[j][1]-1)) {
int temp = b[i][0];
b[i][0] = b[j][0];
b[j][0] = temp;
temp = b[i][1];
b[i][1] = b[j][1];
b[j][1] = temp;
}
}
for (int i = 0; i < z; i++) {
printf("%d ", b[i][0]);
}
}
```