Skip to content

Latest commit

 

History

History
46 lines (35 loc) · 1.53 KB

README.md

File metadata and controls

46 lines (35 loc) · 1.53 KB

Prime count analysis!

Original program

Here is our prime count program.

def count_primes(n):
    count = 0
    for num in range(2, n + 1):
        is_prime = True
        for i in range(2, num):
            if num % i == 0:
                is_prime = False
                break
        if is_prime:
            count += 1
    return count

Using cProfile we see that count_primes is consuming the most time.

python3 -m cProfile -s cumtime python-prime-count.py
5 function calls in 0.397 seconds

   Ordered by: cumulative time

   ncalls  tottime  percall  cumtime  percall filename:lineno(function)
        1    0.000    0.000    0.397    0.397 {built-in method builtins.exec}
        1    0.000    0.000    0.397    0.397 python-prime-count.py:3(<module>)
        1    0.397    0.397    0.397    0.397 python-prime-count.py:3(count_primes)
        1    0.000    0.000    0.000    0.000 {built-in method builtins.print}
        1    0.000    0.000    0.000    0.000 {method 'disable' of '_lsprof.Profiler' objects}
Screen Shot 2024-10-03 at 10 55 52 AM

Looking at count_primes we see that the outer loop iterates from 2 to n + 1 and the inner loop checks if the current number num is divisible by any number less than itself.

This is pretty much a brute-force method and is very inefficient.

Lets optimize!

Switch to the optimize-inner-loop branch to see the inner loop optimization.