//水仙花数是指一个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;
}
运行程序没反应,各位我这程序是有什么问题吗,谢谢