Java基础算法题01——水仙花数

题目:打印出所有的"水仙花数",所谓"水仙花数"是指一个三位数,其各位数字立方和等于该数本身。例如:
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);
		}
	}
}

}

你可能感兴趣的:(Java基础算法题)