Algoteka
Default Language ...
Log in to submit your own samples!

Sieve of Eratosthenes

Problem by oml1111
# Tech tags Title Creator Created date
1 0
2022-11-23 21:54
View all samples for this language (1 verified and 0 unverified)

O(n log log n) solution | C++ |

By oml1111 |
0 likes

An O(nloglogn)O(n \log \log n) implementation of the sieve of Eratosthenes algorithm (nn is the integer up to which we find the primes)

Code

#include <vector>

std::vector<int> sieve_of_eratosthenes(int n) {  // Finds all primes up to n
    std::vector<bool> is_prime(n+1, true);
    std::vector<int> result;  // The found primes
    is_prime[0] = false;
    is_prime[1] = false;
    for(int i=2; i <= n; i++) {
        if(is_prime[i]) {
            result.push_back(i);
            for(int j=i; j <= n/i; j++) {  // We do the for loop this way to prevent integer overflow for large n
                is_prime[i*j] = false;
            }
        }
    }
    return result;
}

int main() {
    std::vector<int> primes = sieve_of_eratosthenes(100);
    return 0;
}

References

functions
std::vector::operator[] en.cppreference.com cplusplus.com
std::vector::vector en.cppreference.com cplusplus.com
classes
std::vector en.cppreference.com cplusplus.com

Problem Description

Implement the Sieve of Eratosthenes algorithm and use it to find all prime numbers up to some integer.

Sieve of Eratosthenes - wikipedia.org

View sample discussion (0 comments)
View problem discussion (0 comments)