#include<stdio.h>
#include<math.h>
int main()
{
int n,a,i,j=1,sum=0;
scanf("%d",&n);
for(i=pow((float)10,n-1);i<pow((float)10,n);i++)
{
sum=0;
for(j=1;j<=n;j++)
{
if(j==n)
{
a=i/(int)(pow((float)10,j-1));
}
a=(int)(i/((int)pow((float)10,j-1)))%10;
sum+=pow((float)a,n);
}
if(sum==i)
{
printf("%d\n",i);
}
}
return 0;
}
1、首先输入数值的位数;
2、遍历n位数的所有数值,进行判断:
(1)除了最高位的数字,直接除以10的(n-1)次方之外;
(2)其他位的数字,先除以10的(j-1)次方,然后再对10进行取模运算即可;
3、累加之后判断所求的数值是否相等,相等就输出即可。