首页 > web前端 > js教程 > 正文

在 JavaScript 中如何有效地确定一个数字是否为素数?

Barbara Streisand
发布: 2024-10-26 17:57:03
原创
946 人浏览过

How can you efficiently determine if a number is prime in JavaScript?

在 JavaScript 中高效验证素数

在计算机编程中,确定给定数字是否是素数是一项基本任务。素数是大于 1 的正整数,除了 1 和它本身之外没有正因数。

检查素性的一种流行方法涉及埃拉托斯特尼筛法。然而,出于性能考虑,可以采用更有效的方法,如以下 JavaScript 实现所示:

let inputValue = 7;
let isPrime = inputValue == 1 ? false : true;  // Because 1 is not prime

for (let i = 2; i < inputValue; i++) {
  inputValue % i == 0 ? isPrime *= false : isPrime *= true;
}

alert(`${inputValue} is ${isPrime ? 'prime' : 'not prime'} number`);
登录后复制

时间和空间复杂度分析

时间上述算法的复杂度为O(sqrt(n)),其中n代表输入值。这是因为循环会迭代所有整数,直至输入数字的平方根,这是对检查直至 n 的所有整数的重大优化。

空间复杂度为 O(1),因为除了原始变量之外,它不需要任何额外的数据结构。

替代方法

在 JavaScript 中检查素数的替代语法是:

const isPrime = num => {
    for (let i = 2, s = Math.sqrt(num); i <= s; i++) {
        if (num % i === 0) return false;
    }
    return num > 1;
}
登录后复制

这种方法实现了与前一种方法相同的时间和空间复杂度,同时利用了更简洁的箭头函数语法。

以上是在 JavaScript 中如何有效地确定一个数字是否为素数?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!