Maison > interface Web > js tutoriel > Comment vérifier efficacement les nombres premiers en JavaScript ?

Comment vérifier efficacement les nombres premiers en JavaScript ?

Susan Sarandon
Libérer: 2024-10-29 20:12:29
original
749 Les gens l'ont consulté

How to Efficiently Check for Prime Numbers in JavaScript?

Comment déterminer les nombres premiers en JavaScript

En JavaScript, l'identification des nombres premiers est une tâche de programmation courante. Un nombre premier est un entier positif supérieur à 1 qui n'est divisible par aucun autre entier positif sauf 1 et lui-même.

Solution 1 : Approche naïve

Le code fourni L'extrait offre un moyen simple de vérifier si un nombre est premier :

<code class="js">let inputValue = 7;
let isPrime = inputValue == 1 ? false : true;

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

alert(`${inputValue} is ${isPrime ? 'prime' : 'not prime'} number`);
Copier après la connexion

Complexité temporelle : O(sqrt(n))

Complexité spatiale : O(1)

Solution 2 : Approche efficace

Une approche améliorée pour vérifier les nombres premiers est :

<code class="js">const isPrime = num => {
  for (let i = 2, s = Math.sqrt(num); i <= s; i++) {
    if (num % i === 0) return false;
  }
  return num > 1;
};</code>
Copier après la connexion

Ce code profite du fait que si un nombre n’est pas premier, son facteur est inférieur ou égal à sa racine carrée. En vérifiant les facteurs jusqu'à la racine carrée, nous pouvons éliminer efficacement les facteurs potentiels.

Complexité temporelle : O(sqrt(n))

Complexité spatiale :O(1)

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal