Évaluation comparative des algorithmes de nombres premiers
Analyse de la complexité temporelle
import timeit
import sys
def basic_prime_check(n):
if n < 2:
return False
for i in range(2, n):
if n % i == 0:
return False
return True
def optimized_prime_check(n):
if n < 2:
return False
for i in range(2, int(n**0.5) + 1):
if n % i == 0:
return False
return True
graph TD
A[Prime Checking Performance] --> B[Input Size]
A --> C[Algorithm Efficiency]
B --> D[Small Numbers]
B --> E[Large Numbers]
C --> F[Time Complexity]
C --> G[Space Complexity]
Méthodes d'évaluation comparative
def benchmark_prime_methods():
test_numbers = [10, 100, 1000, 10000]
results = []
for num in test_numbers:
basic_time = timeit.timeit(lambda: basic_prime_check(num), number=1000)
optimized_time = timeit.timeit(lambda: optimized_prime_check(num), number=1000)
results.append({
'Number': num,
'Basic Method Time': basic_time,
'Optimized Method Time': optimized_time,
'Improvement (%)': ((basic_time - optimized_time) / basic_time) * 100
})
return results
## Print benchmarking results
for result in benchmark_prime_methods():
print(result)
Stratégies d'optimisation
Stratégie |
Description |
Impact sur les performances |
Limite de la racine carrée |
Vérifier les diviseurs jusqu'à √n |
Accélération significative |
Arrêt précoce |
Arrêter la vérification au premier diviseur |
Réduit les itérations inutiles |
Mise en cache |
Stocker les résultats de nombres premiers précédemment calculés |
Réduit les calculs redondants |
Techniques d'optimisation avancées
def cached_prime_check():
## Implement memoization for prime checking
cache = {}
def is_prime(n):
if n in cache:
return cache[n]
if n < 2:
cache[n] = False
return False
for i in range(2, int(n**0.5) + 1):
if n % i == 0:
cache[n] = False
return False
cache[n] = True
return True
return is_prime
## Create cached prime checker
prime_checker = cached_prime_check()
Optimisation de la mémoire
def memory_efficient_prime_generator(limit):
## Use generator for memory-efficient prime generation
def is_prime(n):
if n < 2:
return False
for i in range(2, int(n**0.5) + 1):
if n % i == 0:
return False
return True
return (num for num in range(2, limit) if is_prime(num))
## Example usage
primes = list(memory_efficient_prime_generator(100))
print(primes)
Principes clés d'optimisation
- Réduire les calculs inutiles
- Utiliser des algorithmes efficaces
- Mettre en œuvre des mécanismes de mise en cache
- Prendre en compte la taille et la complexité des entrées
Chez LabEx, nous soulignons l'importance de l'efficacité algorithmique dans la vérification des nombres premiers.
- Complexité temporelle
- Complexité spatiale
- Extensibilité
- Surcoût computationnel
Conclusion
Une vérification efficace des nombres premiers nécessite une approche équilibrée entre l'efficacité algorithmique et la mise en œuvre pratique.