首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

用JS求100以内的质数

质数是指在大于1的自然数中,除了1和它本身以外不再有其他因数的自然数。以下是用JavaScript编写的求100以内质数的代码:

代码语言:txt
复制
function isPrime(num) {
  if (num <= 1) {
    return false;
  }
  for (let i = 2; i <= Math.sqrt(num); i++) {
    if (num % i === 0) {
      return false;
    }
  }
  return true;
}

function getPrimes(n) {
  const primes = [];
  for (let i = 2; i <= n; i++) {
    if (isPrime(i)) {
      primes.push(i);
    }
  }
  return primes;
}

const primesUnder100 = getPrimes(100);
console.log(primesUnder100);

基础概念

  • 质数:只能被1和自身整除的数。
  • 因数:能够整除给定数的数。

代码解释

  1. isPrime函数:判断一个数是否为质数。
    • 如果数小于等于1,返回false
    • 使用一个循环从2到该数的平方根进行检查,如果能被整除,则不是质数。
  • getPrimes函数:获取小于等于n的所有质数。
    • 遍历从2到n的所有数,使用isPrime函数判断每个数是否为质数,如果是则加入结果数组。
  • 调用getPrimes(100):获取100以内的所有质数并打印。

应用场景

  • 数学研究:质数在数论中有重要地位。
  • 密码学:许多加密算法(如RSA)依赖于大质数的性质。
  • 编程练习:常用于初学者练习算法和逻辑思维。

可能遇到的问题及解决方法

  1. 性能问题:对于非常大的数,质数检测可能会很慢。
    • 解决方法:使用更高效的算法,如埃拉托斯特尼筛法。
  • 精度问题:JavaScript中的浮点数运算可能导致误差。
    • 解决方法:确保所有计算都在整数范围内进行,避免不必要的浮点运算。

通过上述代码和方法,可以有效且准确地找到100以内的所有质数。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

Numpy 求100以内质数和

一百以内质数之和 判断是否为质数 判断一个整数是否为质数比较简单,即除了自身和1以外不可被别的数整除。不过根据数学理论证明,不用从2检查到n,到int(sqrt(n))+1即可,可以提高效率。...,从1循环到100,一次判断是否为质数,若是质数,则加到ans上,若不是直接跳过。...def prime_sum_iter(n=100): ans = 0 for i in range(1,n+1): if is_prime(i):...print prime_sum_iter() # %%timeit # 1000 loops, best of 3: 253 µs per loop 1060 利用np向量化方法 利用numpy可以向量化,用更简洁的方式遍历所有的元素...向量化的理解,就本例子而言,循环的思想是每次取一个数,对其判断是否为质数;向量化是取这个数组为变量,直接对其所有元素判断是否为质数,然后返回一个同size的数组。

1.3K50
  • SQL 找出 100 以内的质数

    之前我写了一篇文章 SQL 生成斐波那契数列,在原来的基础上,今天就来实现使用 SQL 获取 100 以内的质数。 先来看下质数的定义(以下定义摘选自百度百科): 质数又称素数。...一个大于1的自然数,除了1和它自身外,不能被其他自然数整除的数叫做质数;否则称为合数。 判断一个大于 2 的正整数是否是质数,通常使用的算法是: 假设该数是 n,用 2 到 ?...第 1 步,生成 2 - 100 的自然数列 如果你已经有了一张数字辅助表,那么可以从这张辅助表中获取 2 - 100 的自然数列。如果什么都没有,则使用下面的脚本就能生成 2 - 100 的数。...第 2 步,找到质数 假如我们要判断 seq 表中的 31 是不是质数,只需检查 seq 表中从 2 - 5 可以整除 31 的有多少个,如果一个也没有,则说明 31 是质数。...: prime -------- 2 3 5 7 ... ... 89 97 100 以内总共有

    1.5K40

    python用递归筛选法求N以内的孪生质数(孪生素数)

    本人最近读完一本书《质数的孤独》,里面讲到孪生质数,就想查一下孪生质数的分布情况。...其中主要用到了计算质数(素数)的方法,搜了一下,排名前几的都是用for循环来做的,感觉略微麻烦了一些,在比较一些还是觉得用递归筛选法来解决这个问题。...新建List,然后从第0位开始,如果后面的能被这个数整除,则从数组中移除改元素,以此类推,最后留下的就是质数(素数)。...python版本与java版本不同,java可以在遍历list的时候删除该元素,可以对循环变量i进行i--的操作,防止以后的get(i)方法报错,python不支持这个操作只能是拿到被删除的元素,然后在遍历结束以后再去删除...:"+str(a)+"----"+str(b)) 这里备注一下:python为了防止内存溢出,限制了递归的深度,所以直接求10000以内的还不行,会报错: RecursionError: maximum

    2.7K20

    java用递归筛选法求N以内的孪生质数(孪生素数)

    本人最近读完一本书《质数的孤独》,里面讲到孪生质数,就想查一下孪生质数的分布情况。...其中主要用到了计算质数(素数)的方法,搜了一下,排名前几的都是用for循环来做的,感觉略微麻烦了一些,在比较一些还是觉得用递归筛选法来解决这个问题。...新建List,然后从第0位开始,如果后面的能被这个数整除,则从数组中移除改元素,以此类推,最后留下的就是质数(素数)。...0) list.remove(i--); } if (list.size() > ++tt) get(list, tt); } 然后再去做相邻元素差求得孪生质数...(孪生素数),贴一下求10000以内孪生质数(孪生素数)全部的代码: List list = new ArrayList(); for (int i = 2; i

    1.8K10

    groovy使用stream语法递归筛选法求N以内的质数

    本人最近读完一本书《质数的孤独》,里面讲到孪生质数,就想查一下孪生质数的分布情况。...其中主要用到了计算质数(素数)的方法,搜了一下,排名前几的都是用for循环来做的,感觉略微麻烦了一些,在比较一些还是觉得用递归筛选法来解决这个问题。...新建List,然后从第0位开始,如果后面的能被这个数整除,则从数组中移除改元素,以此类推,最后留下的就是质数(素数)。...(孪生素数),贴一下求10000以内孪生质数(孪生素数)全部的代码: List list = new ArrayList(); for (int i = 2; i...,我觉得最大的优势有两点,第一:于java兼容性非常好,大部分时候吧groovy的文件后缀改成java直接可以用,反之亦然。

    1.7K30

    Python应用之求100以内的奇数和

    在数学中,我们需要用到很多求和的办法,比如说求1至100的和,还有100以内的所有偶数和和所有奇数和,如果我们慢慢地计算是不是很浪费时间,还容易出错。...1.解题的思路 对100以内的奇数求和,有四种常见的解题方法: 用range函数遍历100以内的奇数,然后用sum函数求和 for 循环嵌套if语句,将100以内的奇数相加求和 while...循环将100以内的奇数相加,并打印求和 用递归方法求和 2.解题方法 方法一: sum函数 print(sum(range(1, 100, 2))) 首先用range函数创建了一个整数列表,range...然后用sum函数对100以内的奇数求和最后用print函数将求和结果打印出来 这行代码充分体现了Python 语言的简洁性!!!...count += number print(count) 第1行: 设置一个变量count, 初始赋值为0 第3行: 用for循环遍历100以内所有的整数 第4-6行: 用if语句判断100以内的数是否为奇数

    2.6K20

    面试真题:求100万内的质数

    一个头发稀少、穿着格子衬衣的中年男子走了进来,把手里拿的MAC放在桌子上,对我说:“我会用电脑记录面试过程,你不要介意啊”。 我回答到:“没关系。”...面试官:“先来一点基础的算法题吧,用Java写一个方法,求100万内的质数。”...我心中暗想确实很基础,质数不就是除了1和自身外无法被其他数整除的数嘛,于是便写下: public static List findPrime(){ List...不过再想想,有什么可以优化的地方?” 我想了想,说:“好像没有什么可以优化的?” 我左思右想一番,说:“应该没有吧。” 面试官说:“确定没有了嘛?” 我肯定地回答:“确定没有了。”...我有点不服气,抢着问到:“您说说,还有什么可以优化的地方?” 面试官微笑了一下,说:“还可以利用之前计算出质数做整除就可以了,性能至少可以提升一倍。”

    42940

    Prime numbers from 1 to 100 (打印 100 以内的素数)

    问题描述 下面是有关这个问题的描述部分。 中文 题目要求非常简单,就是将 100 以内的素数打印出来就可以了。 在做题之前,需要了解的就是有关素数的定义:质数又称素数。...一个大于1的自然数,除了1和它自身外,不能被其他自然数整除的数叫做质数;否则称为合数(规定1既不是质数也不是合数)。...质数被利用在密码学上,所谓的公钥就是将想要传递的信息在编码时加入质数,编码之后传送给收信人,任何人收到此信息后,若没有此收信人所拥有的密钥,则解密的过程中(实为寻找素数的过程),将会因为找质数的过程(分解质因数...质素的用途比较高端,说白了就是在计算机科学中可以被用在密码学上面。比如说 Java 中用的 Hash 算法就用到了质素。 因此很多面试题喜欢考察 100 以内的素数。...100以内的质数有 2,3,5,7,11,13,17,19,23,29,31,37,41,43,47,53,59,61,67,71,73,79,83,89,97,在100内共有25个质数。

    88640
    领券