主要是写法。其实实现功能很简单,有N种写法,但是百度了一下,看到网上很多种写法。功能是实现了,但是代码的阅读性比较差。
#include <math.h>
#include<stdio.h>
int main()
{
int start;//输入要计算的范围开始
scanf_s("%d", &start);
int end; //输入要计算的范围结束
scanf_s("%d", &end);
for (int i = start; i < end; i++)
{
//例如i=123
//1:计算i的位数n
int n = 1;
int tmp = i;
while (tmp / 10) /** 123 进来 123/10得12进入。12/10得1进入,1/10得0进不来了 */
{
n++;
tmp = tmp / 10;//123 进来 123/10得12。12再进来12/10得1
}
//2:计算i的每一位n次方之和sum
tmp = i;
int sum = 0;
while (tmp) //123 模10得23进去。12模10得2进去
{
/** 123,模10得3(算3的平方)。12模10得2(算2的平方)。 1模10得1(算1的平方)*/
sum = sum + pow(tmp % 10, n);
tmp = tmp / 10; /**123/10->12,12/10->1,1/10->0 */
}
//3:判断i是否等于sum
/** 如果需要输出指定位数,例如三位,四位。可写 && if (sum == i && n==3)*/
if (sum == i) {
printf("%d ", i);
}
}
return 0;
}
这篇文章不是我的原创,而是通过网上的视频学习看到的。觉得这种写法代码阅读理解方便,就记一下分享出来。主要是看这个写法。我看网上其他的写法都是循环循环再循环,嵌套加嵌套。而且计算的部分没介绍。
我写了一些注释,方便理解。如果还有不理解的,可以留言。如果有BUG提出来。我在真机上运行过,没问题。