#include
int main()
{
int n;
scanf("%d",&n);
int i=1;
int min=1;
for(i=1;i
min*=10;
}
int b=min;//min用来控制下限
for(b=min;b10;b++){
int m=b;//m用来替换b,以免b最终成为0;
int l=0;//l用来求每位数的n次的值
while(m>0){
int j,k;
int y=1;
int l;
j=m%10;
m/=10;
for(k=1;k/为啥这里y的值永远是0;
}if(b==l){
printf("%d位数的水仙花数有%d",n,l);
}
}
return 0;
}
你的代码是用来求任意位数的水仙花数的吗?有些地方有点问题:
long
类型,否则在求解较大位数的水仙花数时,可能会超出整型的数值范围l
,必须去掉\n
换行符号,这样方便查看打印效果,不然所有的结果都会输出在一行中