我的水仙花数代码哪里出错了?

#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;

}

你的代码是用来求任意位数的水仙花数的吗?有些地方有点问题:

  1. 数据类型应该使用 long 类型,否则在求解较大位数的水仙花数时,可能会超出整型的数值范围
  2. 内层循环重复定义了变量 l,必须去掉

    img

  3. 这里求 n 次幂的循环条件有问题,假设 n = 3,那么循环只会执行两次,得到的值是2次幂,而不是3次幂

    img

  4. 最后, printf() 函数应该加个 \n 换行符号,这样方便查看打印效果,不然所有的结果都会输出在一行中

    img