一、什么是水仙花数

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

水仙花数是指一个三位数,每个位数上数字的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. javase程序设计上机作业1

    package javaxgp.teacher.test; import java.math.BigInteger; import java.util.Scanner; import java.uti ...

  2. python 并发编程 多进程 生产者消费者模型总结

    生产者消费者模型总结 生产者消费者模型什么时候用? 1.程序中有两类角色 一类负责生产数据(生产者) 一类负责处理数据(消费者) 2.引入生产者消费者模型为了解决的问题是 平衡生产者与消费者之间的速度 ...

  3. noip2018day1-赛道修建

    题目描述 \(C\) 城将要举办一系列的赛车比赛.在比赛前,需要在城内修建 $m $条赛道. \(C\) 城一共有 \(n\) 个路口,这些路口编号为 \(1,2,-,n\)有 $n-1 $条适合于修 ...

  4. gRPC编译教程

    windows平台的编译 一.编译openssl ① 安装perl(可以使用ActivePerl),执行perl Configure VC-WIN64A no-asm .在这里解释一下参数含义,VC- ...

  5. Spring Boot解决无法访问图片的问题

    找了很多Spring Boot项目访问图片的解决方式,发现都是配置的,有时配置了也没有用.然后自己研究了一种简单操作的方法. 1,在Spring Boot的static目录下创建一个新目录img(或者 ...

  6. python中的元类介绍

    类也是对象 在大多数编程语言中,类就是一组用来描述如何生成一个对象的代码段,在python中也是成立的. class ObjectCreator: pass my_object = ObjectCre ...

  7. Jade学习(四)之结合node如何编译执行

    1.首先安装node 2.新建一个文件夹并进入该文件夹 3.安装jade 4.在新建的文件夹下新建js文件,写nodejs代码 5.在vscode中利用插件code runner直接执行js文件,输出 ...

  8. ubuntu安装selenium谷歌插件

    爬虫之selenium 安装与 chromedriver安装 今天学到一个有意思的插件,就是chromedriver,在爬虫的时候,如果网站反爬虫做的很好,自己又很想爬去里面的数据,那就可以用这个插件 ...

  9. 动态代理之JDK 和 CGLIB

    方式一:jdk动态代理 通过proxy类的newProxyInstance(ClassLoader loader, Class<?>[] interfaces,InvocationHand ...

  10. python cv2展示网络图片、图片编解码、及与base64转换

    从网络读取图像数据并展示 需要使用cv2.imdecode()函数,从指定的内存缓存中读取数据,并把数据转换(解码)成图像格式:主要用于从网络传输数据中恢复出图像. # -*- coding: utf ...