题目描述
水仙花数是指一个3位数,它的每一位数的立方之和等于这个数本身。例如153,1X1X1+5X5X5+3X3X3=1+125+27=153,则153是水仙花数。
请你找出100~999中所有的水仙花数。
思路:因为水仙花数是3位数,因此,我们知道水仙花数的范围一定是在100~999之间,把所有的三位数都列举出来,for(int i=100;i<=999;i++),然后一个一个地判断 i 有没有满足各位三次方之和等于本身的数,符合条件的就把它打印出来。
注意:因为每个三位的整数都要判断一遍个位、十位、百位是否满足条件,所以将gw、sw、bw的计算放在循环体中。
int gw, sw, bw;
for (i从100~999){
算出i的个位;
算出i的十位;
算出i的百位;
if (个位*个位*个位 + 十位*十位*十位 + 百位*百位*百位 == i)
输出i;
}
输入描述
rt
输出描述
rt
输入样例
输出样例
153 370 371 407
#include <iostream>
using namespace std;
int main() {
int gw, sw, bw;
for(int i =100; i <=999;i++){
int gw =i%10;
int sw =i/10%10;
int bw =i/100;
if (gw*gw*gw+sw*sw*sw+bw*bw*bw==i)
cout << i<< " ";
}
return 0;
}