1.水仙花数
水仙花数:
水仙花数(Narcissistic Number),也称为自恋数、自幂数或阿姆斯壮数,是指一个 n 位数(n≥3),它的每个位上的数字的 n 次幂之和等于它本身。具体而言,一个 n 位数 m 满足:
m=d1n+d2n+…+dnn
其中d1,d2,…dn是数字m的各个位数。
以三位数为例,水仙花数是指满足下列条件的三位数:
abc=d3+d3+d3
例如,153 是一个水仙花数,因为13+53+33=153。
水仙花数是一种数学趣题,它得名于古代希腊神话中的美丽英俊的青年 Narcissus,故而得名自恋数。这个概念对于学习编程、数学和算法的初学者来说,常常是一个有趣的练习和学习案例。
2.水仙花数的算法
(100~10000)水仙花数计算方法:
public static void main(String[] args) {
//定义变量count,用于保存”水仙花数”的数量,初始值为0
int count = 0;
//输出所有的水仙花数必然要使用到循环,遍历所有的三位数,三位数从100开始,到999结束
for(int i=100; i<10000; i++) {
//在计算之前获取三位数中每个位上的值
int ge = i%10;
int shi = i/10%10;
int bai = i/10/10%10;
//在判定水仙花数的过程中,满足条件不再输出,更改为修改count的值,使count+1
if(ge*ge*ge + shi*shi*shi + bai*bai*bai == i) {
count++;
}
}
//打印输出最终结果
System.out.println("水仙花共有"+count+"个");
}