Sieve of Eratosthenes Algorithm:
| From: | To: | 
The Sieve of Eratosthenes is an ancient algorithm for finding all prime numbers up to any given limit. It is one of the most efficient ways to find small primes and was created by the Greek mathematician Eratosthenes in the 3rd century BC.
The algorithm works by iteratively marking the multiples of each prime number starting from 2:
Key Steps:
Detailed Process:
                    1. Create a boolean array of size n+1, initialize all as true
                    2. Mark positions 0 and 1 as false (not prime)
                    3. For i from 2 to √n:
                       - If isPrime[i] is true, mark all multiples of i as false
                    4. All remaining true positions are prime numbers
                
Instructions: Enter an upper limit (n) between 2 and 10,000. The calculator will find all prime numbers up to that limit using the Sieve of Eratosthenes algorithm and display the results with execution time.
                    Q1: What is the time complexity of this algorithm?
                    A: The Sieve of Eratosthenes has a time complexity of O(n log log n), making it very efficient for finding primes up to moderate limits.
                
                    Q2: What is the space complexity?
                    A: The space complexity is O(n) as it requires an array of size n+1 to track prime status.
                
                    Q3: Why do we only check up to √n?
                    A: Any composite number n must have a prime factor less than or equal to √n, so checking beyond that is unnecessary.
                
                    Q4: What are the limitations of this algorithm?
                    A: The main limitation is memory usage for very large n. For extremely large numbers, other algorithms like Miller-Rabin primality test are more suitable.
                
                    Q5: Can this algorithm be optimized?
                    A: Yes, optimizations include checking only odd numbers after 2, and starting marking from i² rather than 2*i.