卿云861 2021-11-02 19:48 采纳率: 97.8%
浏览 40
已结题

这个用c语言写的,结果运行超时,求改正!错误代码如下

水仙花数是指一个N位正整数(N≥3),它的每个位上的数字的N次幂之和等于它本身。例如:153=1
3
+5
3
+3
3
。 本题要求编写程序,计算所有N位水仙花数。

输入格式:
输入在一行中给出一个正整数N(3≤N≤7)。

输出格式:
按递增顺序输出所有N位水仙花数,每个数字占一行。

输入样例:
3
结尾无空行
输出样例:
153
370
371
407
结尾无空行

int main()
{
int n,x,y,m,sum=0,a;
scanf("%d",&n);
y=pow(10,n);
a=pow(10,n-1);
for(a;x<y;a++)
{
n=a;
while(n==0)
{
m=n%10;
sum=sum+pow(m,x);
n=n/10;
}
if(a=sum)
{printf("%d",a);}
}
return 0;
}

  • 写回答

1条回答 默认 最新

  • 舟桥居士 2021-11-02 20:09
    关注

    你的上一个相同提问已经明确回答

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 11月11日
  • 已采纳回答 11月3日
  • 创建了问题 11月2日