Optimización de rendimiento
Realización de pruebas comparativas de algoritmos de números primos
Análisis de la complejidad temporal
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
Comparación de rendimiento
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étodos de prueba comparativa
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)
Estrategias de optimización
Estrategia |
Descripción |
Impacto en el rendimiento |
Límite de la raíz cuadrada |
Comprobar divisores hasta √n |
Aumento significativo de velocidad |
Terminación temprana |
Detener la comprobación al encontrar el primer divisor |
Reduce las iteraciones innecesarias |
Caché |
Almacenar los resultados de números primos previamente calculados |
Reduce los cálculos redundantes |
Técnicas de optimización avanzadas
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()
Optimización de memoria
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)
Principios clave de optimización
- Reducir los cálculos innecesarios
- Utilizar algoritmos eficientes
- Implementar mecanismos de caché
- Tener en cuenta el tamaño y la complejidad de la entrada
En LabEx, enfatizamos la importancia de la eficiencia algorítmica en la comprobación de números primos.
Métricas de rendimiento
- Complejidad temporal
- Complejidad espacial
- Escalabilidad
- Sobrecarga computacional
Conclusión
Una comprobación efectiva de números primos requiere un enfoque equilibrado entre la eficiencia algorítmica y la implementación práctica.