我写的水仙花数程序哪里有问题

//水仙花数是指一个N位正整数(N>=3) ,它的每个位上的数字的N次幂之和等于它本身 153=1³+5³+3³
#include <stdio.h>
int main()
{
int n;
printf("请输入想得到多少位(最少3位数)之间的水仙花数:");
scanf("%d", &n);
int a = 0; //记录位数
int b = 1; //最大数
while (n > 0)
{

    b *= 10;
    a++;
    n--;
}
for (int i = 100; i < b; i++)
{
    int c = i; // c保存i

    int sum = 0;
    while (c > 0)
    {
        int d;
        d = c % 10;
        for (int j = 1; j < a; j++) //假设3位数,本身一次,所以j要从1开始,两个循环2次就行
        {
            d *= d;
        }
        sum += d;
        c /= 10;
    }
    if (sum == i)
    {
        printf("%d\n ", i);
    }
}

return 0;

}

运行程序没反应,各位我这程序是有什么问题吗,谢谢

修改处见注释,供参考:

#include <windows.h>
#include <stdio.h>
int main()
{
    int n;
    printf("请输入想得到多少位(最少3位数)之间的水仙花数:");
    scanf("%d", &n);
    int a = 0; //记录位数
    int b = 1; //最大数
    while (n > 0)
    {
        b *= 10;
        a++;
        n--;
    }
    for (int i = b / 10; i < b; i++)  //for (int i = 100; i < b; i++) 修改
    {
        int c = i, sum = 0; // c保存i
        while (c > 0)
        {
            int d = 1;    //修改
            //d = c % 10; 修改
            for (int j = 1; j <= a; j++) //假设3位数,本身一次,所以j要从1开始,两个循环2次就行 修改
            {
                d *= c % 10;   //修改
            }
            sum += d;
            c /= 10;
        }
        if (sum == i)
        {
            printf("%d\n", i);// 修改
        }
    }
    return 0;
}

for (int i = 100; i < b; i++)
你不应该从100开始,应该从10的a-1次方开始

你可以参考下这篇文章:练习题-水仙花数