C语言习题:求出0〜999之间的所有“水仙花数”并输出
“水仙花数”是指一个三位数,其各位数字的立方和确好等于该数本身
例如153、370、371及407就是三位数的水仙花数,其各个数之立方和等于该数:
153 = 1^3 + 5^3 + 3^3。
370 = 3^3 + 7^3 + 0^3。
371 = 3^3 + 7^3 + 1^3。
407 = 4^3 + 0^3 + 7^3。
思路一:math.h中的pow函数
#include <stdio.h>
#include <math.h>
int main() {
// insert code here...
int n = 0;
for (n = 0; n < 1000; n++) {
int i = n / 100; //百位
int j = (n / 10) % 10; //十位
int k = n % 10; //个位
if (n == pow(i, 3) + pow(j, 3) + pow(k, 3)) {
printf("%d ", n);
}
}
printf("\n");
}
注意点:不需要在0~9,10~99,100~999分类讨论,因为对于个位数而言,例如8,
8 / 100 = 0;
(8/10)% 10 = 0;
8 % 10 = 8
当然由于是三次方,可以不使用pow函数,可以直接用i*i*i + j*j*j + k*k*k计算
运行结果: