水仙花数
想起我学Java遇到的第一个比较困难的问题那就是:打印出所有的水仙花数,所谓的水仙花数是指一个三位数其个十百位的立方和等于本身,例如:153= 1 3 1^{3} 13+ 5 3 5^{3} 53+ 3 3 3^{3} 33
public static void main(String[] args) {
for (int i = 100; i < 1000; i++) {//先循环1000以内所有的三位数
if (isShui(i)) {//调用方法进行判断是否为水仙花数,并进行打印
System.out.println(i);
}
}
}
public static boolean isShui(int i) {//通过输入i判断是否为水仙花数
int a, b, c;//定义三个整数
a = i / 100;//获取百位的数
b = i % 100 / 10;//获取十位的数
c = i % 10;//获取个位的数
if (a * a * a + b * b * b + c * c * c == i) {//如果结果相等于则返回,否则判定下一个
return true;
} else {
return false;
}
}
刚碰到这样的问题的时候,真就想破头也想不出来,思维跟不上,不知道如何去获取每一个值,如何做的更合理,现在看来只是一个很简单的题目,对于没学过没写过的人估计就是这么一个简单的题目都解答不了,这就是入门的难处吧,学好思维之后,世界都是不一样了。