题目:打印出所有的"水仙花数",所谓"水仙花数"是指一个三位数,其各位数字立方和等于该数本身。例如:
153是一个"水仙花数",因为153=1的三次方+5的三次方+3的三次方。
1.程序分析:利用for循环控制100-999个数,每个数分解出个位,十位,百位,再用if判断个位,十位,百位的立方和是否与这个数本身相等。
//首先声明三个整形用来储存个位,十位,百位
int a,b,c;
//for循环遍历100-999之间的三位数
for(int i = 100;i<=999;i++){
//分别获取个位,十位,百位,并且给刚刚三个整形赋值
a=i%10;
b=i/10%10;
c=i/100%10;
//如果三个数的立方等于其本身则输出
if((c*c*c+b*b*b+a*a*a)==i){
System.out.println(i);
}
完整程序
package Java_FindDaffodilNumber;
//题目:打印出所有的"水仙花数",所谓"水仙花数"是指一个三位数,其各位数字立方和等于该数本身。例如:
//153是一个"水仙花数",因为153=1的三次方+5的三次方+3的三次方。
//1.程序分析:利用for循环控制100-999个数,每个数分解出个位,十位,百位。
public class FindDaffodilNumber {
public static void main(String[] args) {
int a,b,c;
for(int i = 100;i<=999;i++){
a=i%10;
b=i/10%10;
c=i/100%10;
if((c*c*c+b*b*b+a*a*a)==i){
System.out.println(i);
}
}
}
}