题目简述
用户输入一个数,判断这个输入的数是不是水仙花数
那么什么是水仙花数呢:
**水仙花数(Narcissistic number)**也被称为超完全数字不变数(pluperfect digital invariant, PPDI)、自恋数、自幂数、阿姆斯壮数或阿姆斯特朗数(Armstrong number)
水仙花数的特征水仙花数是指一个 n 位数 ( n≥3 ),它的每个位上的数字的 n 次幂之和等于它本身。(例如:111 + 555 + 333 = 153)
需求分析和实现(这里把他封装方便调用)
- 首先定义一个函数,函数有一个形参,用于用户输入这个数,这里我们默认用户输入的是一个数字而不是别的
- 判断这个数是否是一个三位数以上的数以及整数,如果不是直接返回"水仙花数是一个三位数以上的整数,你输入的数不是一个水仙花数"
- 当他输入的数符合要求时
- 定义一个计数的和,定义一个新变量存储这个数字变成字符串后的值
- 首先利用substr()方法截取他的每一位
- 利用循环把他的每一位三次幂计算出来,并相加
- 最后比较结果,如果这个和与用户输入的数字相等,那么这个数就是一个水仙花数;反之,这不是一个水仙花数。
- 要用的时候直接调用即可
function numDaffodils(num) {
// 判断他是不是一个三位数以上的数以及整数
if (num < 100 && num % 1 != 0) {
return "水仙花数是一个三位数以上的整数,你输入的数不是一个水仙花数"
} else {
// 截取数字的每一位
// 把他转换成字符串
var str = String(num)
//定义一个变量算和
count = 0;
// 每个位上的数字的 3 次幂之和等于它本身
for (var i = 0; i < str.length; i++) {
count += str.substr(i, 1) ** 3
}
// 检测输出的结果是否准确
// console.log(count)
// 判断原来的数是否等于他的每个位置上的三次幂的和
if (count == num) {
return ('这是一个水仙花数')
} else {
return ('这不是一个水仙花数')
}
}
}
当然当规定几位数是固定的时候,我们还可以用%和/等基本运算符计算出每一位,由于比较简单,实用性不如这个,这里不做展示