计算阿姆斯特朗数
#include
int main()
{
long n,b,i,m=1,l,o,k,q,p=0;
scanf("%d",&n);
for(b=1;b<=n;b++)
m*=10;
l=10*m;
for(m<l;m++;)//算所有n位数
{ o=m;
for(i=1;i<=n;i++)// 几位
{
for(k=1;k<=n;k++) //对每一位
{
q=o%10;
q=q*q;
}
o=m/10;
p=p+q;
}
if(m==p)
printf("%d\n",m);
}
return 0;
}
刚刚开始学c语言,真的看不出来,求大佬们帮帮忙。
抱歉,之前没有说清楚,输入的n是位数
浏览代码分析,(都没有标行数,描述不方便啊),循环逻辑整个都不太对,可以百度参考c代码实现;
首先计算输入n的位数,通过循环除10计算;
其次计算各位值的乘方累加值,通过循环模10并循环乘方累加得到;
最后比较输入与最终的乘方累加值,输出结果;
代码百度都有,不贴了
for(m<l;m++;)//算所有n位数 改为for(;m<l;m++)
不知道你这个问题是否已经解决, 如果还没有解决的话: