一、什么是水仙花数

水仙花数也称为超完全数字不变数、自幂数、阿姆斯壮数、阿姆是特朗数。

水仙花数是指一个三位数,每个位数上数字的3次幂之和等于数字它本身。

水仙花数是自幂数的一种,三位的三次自幂数才叫做水仙花数;三位的水仙花数总够有4个:153,370,371,470

二、通过JS取得水仙花数

思路分析:

1、使用for循环查找遍历 从100到 999的所有三位数;

2、判断遍历的数字是否是各个位数的数字的3次幂数之和是否等于数字本身,如果是即为水仙花数,则在控制台输出(如何选取各个位数)

(1)选取个位数  模以10,得到余数即为个位数

(2)选取十位数  i除以10,再对结果进行取整,取整后得到一个两位数的整数。用这个结果对10取模,得到十位数

(3)选取百位数  三位数除以100,再取整,就得到了百位数。

3、使用 if语句 判断 i 是否是水仙花数。Math对象用于执行数学任务,pow(x , y)函数用于求取 x 的 y 次幂。

 for(var i = 100;i<=999;i++){
var gw = i%10;
var sw = parseInt(i/10) % 10;
var bw = parseInt(i/100);
if(i == Math.pow(gw,3)+Math.pow(sw,3)+Math.pow(bw,3)){
console.log(i);
}
}

输出结果为:

三、求取其他的自幂数

  • 一位自幂数:独身数
  • 两位自幂数:没有
  • 三位自幂数:水仙花数
  • 四位自幂数:四叶玫瑰数
  • 五位自幂数:五角星数
  • 六位自幂数:六合数
  • 七位自幂数:北斗七星数
  • 八位自幂数:八仙数
  • 九位自幂数:九九重阳数
  • 十位自幂数:十全十美数

1、四叶玫瑰数 (1634,8208,9474)

 for(var i = 1000;i<=9999;i++){
var gw = i%10;
var sw = parseInt(i/10)%10;
var bw = parseInt(i/100)%10;
var qw = parseInt(i/1000);
if(i == Math.pow(gw,4)+Math.pow(sw,4)+Math.pow(bw,4)+Math.pow(qw,4)){
console.log(i);}
}

2、五角星数 (54748, 92727,93084)

console.time('五角星数');
for(var i = 10000;i<=99999;i++){
var gw = i%10;
var sw = parseInt(i/10)%10;
var bw = parseInt(i/100)%10;
var qw = parseInt(i/1000)%10;
var ww = parseInt(i/10000);
if(i==Math.pow(gw,5)+Math.pow(sw,5)+Math.pow(bw,5)+Math.pow(qw,5)+Math.pow(ww,5)){
console.log(i);}
}
console.timeEnd('五角星数');

 注意:这里面使用 console.time() 和 console.timeEnd() 来计算 运行的时间

console.time() 方法是作为计算器的起始方法,该方法一般用于测试程序执行的时长。

console.timeEnd() 方法为计算器的结束方法,并将执行时长显示在控制台。

6、六合数(548834)

 console.time('六合数');
for(var i = 100000;i<=999999;i++){
var gw = i%10;
var sw = parseInt(i/10)%10;
var bw = parseInt(i/100)%10;
var qw = parseInt(i/1000)%10;
var ww = parseInt(i/10000)%10;
var shw = parseInt(i/100000);
if(i==Math.pow(gw,6)+Math.pow(sw,6)+Math.pow(bw,6)+Math.pow(qw,6)+Math.pow(ww,6)+Math.pow(shw,6)){
console.log(i);}
}
console.timeEnd('六合数');

7、北斗七星数(1741725,4210818,9800817,9926315)

console.time('北斗七星数');
for(var i = 1000000;i<=9999999;i++){
var gw = i%10;
var sw = parseInt(i/10)%10;
var bw = parseInt(i/100)%10;
var qw = parseInt(i/1000)%10;
var ww = parseInt(i/10000)%10;
var sww = parseInt(i/100000)%10;
var qww = parseInt(i/1000000);
if(i==Math.pow(gw,7)+Math.pow(sw,7)+Math.pow(bw,7)+Math.pow(qw,7)+Math.pow(ww,7)+Math.pow(sww,7)+Math.pow(qww,7)){
console.log(i);}
}
console.timeEnd('北斗七星数');

8、八仙数(24678050,24678051,8859347)

 console.time('八仙数');
for(var i = 10000000;i<=99999999;i++){
var gw = i%10;
var sw = parseInt(i/10)%10;
var bw = parseInt(i/100)%10;
var qw = parseInt(i/1000)%10;
var ww = parseInt(i/10000)%10;
var sww = parseInt(i/100000)%10;
var qww = parseInt(i/1000000)%10;
var www = parseInt(i/10000000);
if(i==Math.pow(gw,8)+Math.pow(sw,8)+Math.pow(bw,8)+Math.pow(qw,8)+Math.pow(ww,8)+Math.pow(sww,8)+Math.pow(qww,8)+Math.pow(www,8)){
console.log(i);}
}
console.timeEnd('八仙数');

补充一些其他的Math对象:

  • Math.pow(2,53) // => 9007199254740992:  2 的 53次幂
  • Math.round(.6) // => 1.0:   四舍五入
  • Math.ceil(.6) // => 1.0:   向上求整
  • Math.floor(.6) // => 0.0:   向下求整
  • Math.abs(-5)// => 5:   求绝对值
  • Math.max(x,y,z)    返回最大值
  • Math.min(x,y,z)   返回最小值
  • Math.random()   生成一个大于等于0小于1.0的伪随机数
  • Math.PI // π: 圆周率
  • Math.E // e: 自然对数的底数
  • Math.sqrt(3)   3的平方根
  • Math.pow(3, 1/3)   3的立方根
  • Math.sin(0)    三角函数: 还有Math.cos, Math.atan等
  • Math.log(10)   10的自然对数
  • Math.log(100)/Math.LN10   以10为底100的对数
  • Math.log(512)/Math.LN2    以2为底512的对数
  • Math.exp(3)   e的三次幂

通过JS来得到一系列的自幂数,是有一定的规律在里面的,有兴趣的话可以动手尝试一下,如果看了这篇博客能有所帮助的话,不胜荣幸~

JavaScript求取水仙花数的更多相关文章

  1. 求取水仙花数 && 将整数分解成质因数

    [程序3] 题目:打印出所有的"水仙花数",所谓"水仙花数"是指一个三位数,其各位数字立方和等于该数本身.例如: 153是一个"水仙花数", ...

  2. 求n位水仙花数

    求n位水仙花数 A.两个关键 1.n位水仙花数的范围是什么? n位水仙花数的范围是[10n-1,10n) 2.如何判断是否为水仙花数 核心操作: 2-1.如何得到每一位? A.核心思想 对得到的数进行 ...

  3. java实现求二十一位水仙花数(21位水仙花数)

    一个N位的十进制正整数,如果它的每个位上的数字的N次方的和等于这个数本身,则称其为花朵数. 例如: 当N=3时,153就满足条件,因为 1^3 + 5^3 + 3^3 = 153,这样的数字也被称为水 ...

  4. php 求水仙花数优化

    水仙花数是指一个n位数(n>=3),它每一个位上数字的n次幂之和等于它本身,n为它的位数.(比如:1^3+5^3+3^3 = 153) 水仙花数又称阿姆斯特朗数. 三位的水仙花数有4个:153, ...

  5. acm水题3个:1.求最大公约数;2.水仙花数;3.判断完数

    //7.求两个整数的最大公约数#include<stdio.h>//用穷举法求出最大公约数int gcd1(int m,int n){ int min = m > n ? n : m ...

  6. 二、求水仙花数,打印出100-999之间所有的"水仙花数"

    所谓"水仙花数"是指一个三位数,其各位数字立方和等于该数本身. 例如:153是一个"水仙花数",因为153=1的三次方+5的三次方+3的三次方 public c ...

  7. C#学习笔记(29)——Linq的实现,Lambda求偶数和水仙花数

    说明(2017-11-22 18:15:48): 1. Lambda表达式里面用了匿名委托,感觉理解起来还是挺难的.求偶数的例子模拟了Linq查询里的一个where方法. 2. 蒋坤说求水仙花数那个例 ...

  8. 用js 的for循环打印三角形,提取水仙花数,求本月多少天

    第一题:用for循环打印三角形 //第一个 for(var x = 1;x <= 4;x++){ //控制行数 :由 1 到 4 for(var y = 1;y <= x;y++){ // ...

  9. js中求水仙花数

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

随机推荐

  1. SQL子连接案例

    子查询 何时使用子查询 1. 子查询作为数据源 2. 数据加工 需求:根据不同顾客的所有的账户余额划分区间,进行分组 sql语句实现如下: select 'Small Fry' name , 0 lo ...

  2. 【神经网络与深度学习】在Windows8.1上用VS2013编译Caffe并训练和分类自己的图片

    最近想熟悉一下深度学习,体验了一下Caffe,简单写写训练和分类的过程: 1.下载Caffe VS2013工程:https://github.com/Microsoft/caffe 2. 解压并用VS ...

  3. 【VS开发】【智能语音处理】语音信号处理之(一)动态时间规整(DTW)

    语音信号处理之(一)动态时间规整(DTW) zouxy09@qq.com http://blog.csdn.net/zouxy09 这学期有<语音信号处理>这门课,快考试了,所以也要了解了 ...

  4. 微信小程序开发(三)----- 云开发案例

    1.发送请求 2.云函数中发送请求,例子request https://github.com/request/request-promise    创建云函数movielist,右键在终端打开,输入  ...

  5. 小记---------Hadoop的MapReduce基础知识

    MapReduce是一种分布式计算模型,主要用于搜索领域,解决海量数据的计算问题 MR由两个阶段组成:Map和Reduce,用户只需要实现map()和reduce()两个函数,即可实现分布式计算. 两 ...

  6. semantic-ui的表单使用

    semantic-ui 的表单使用 最近找了一款ui库,jquery可以使用的.可以进行个性化定制,感觉还不错. 现状 简单阐述下该ui的现状吧,目前止步于2.4的版本,github商讨了一波.大致是 ...

  7. github项目多人进行合作开发,填坑记录

    1.Fork别人的github项目. Fork项目成功后,再进行把项目克隆到你本地.(我的项目已经克隆到本地了,右边是克隆下来的所有文件,除了 node_modules) git命令: git clo ...

  8. 推荐JavaScript动态效果库

    翻译:疯狂的技术宅,原文:https://blog.bitsrc.io/11-javascript-animation-libraries-for-2018-9d7ac93a2c59 当我想要在网上找 ...

  9. vue.js(4)--字符串跑马灯

    制作一个字符串的跑马灯效果 (1)实例代码 <!DOCTYPE html> <html lang="en"> <head> <meta c ...

  10. js 动态生成表格案例

    <1>布局:一个table表格,表格分为两个部分,上面是thead表头,表头里面仅一行,有4列(th),   下面是tbody表格内容,要求tbody中的每一行都是用js动态创建的 < ...