This documentation is automatically generated by online-judge-tools/verification-helper
View the Project on GitHub ebi-fly13/Library
#include "math/eratosthenes_sieve.hpp"
$N$ 以下の素数を列挙する。 $O(N\log \log N)$
#pragma once #include <cassert> #include <cstdint> #include <vector> /* reference: https://37zigen.com/sieve-eratosthenes/ */ namespace ebi { struct eratosthenes_sieve { private: using i64 = std::int_fast64_t; int n; std::vector<bool> table; public: eratosthenes_sieve(int _n) : n(_n), table(std::vector<bool>(n + 1, true)) { table[1] = false; for (i64 i = 2; i * i <= n; i++) { if (!table[i]) continue; for (i64 j = i; i * j <= n; j++) { table[i * j] = false; } } } bool is_prime(int p) { return table[p]; } std::vector<int> prime_table(int m = -1) { if (m < 0) m = n; std::vector<int> prime; for (int i = 2; i <= m; i++) { if (table[i]) prime.emplace_back(i); } return prime; } }; } // namespace ebi
#line 2 "math/eratosthenes_sieve.hpp" #include <cassert> #include <cstdint> #include <vector> /* reference: https://37zigen.com/sieve-eratosthenes/ */ namespace ebi { struct eratosthenes_sieve { private: using i64 = std::int_fast64_t; int n; std::vector<bool> table; public: eratosthenes_sieve(int _n) : n(_n), table(std::vector<bool>(n + 1, true)) { table[1] = false; for (i64 i = 2; i * i <= n; i++) { if (!table[i]) continue; for (i64 j = i; i * j <= n; j++) { table[i * j] = false; } } } bool is_prime(int p) { return table[p]; } std::vector<int> prime_table(int m = -1) { if (m < 0) m = n; std::vector<int> prime; for (int i = 2; i <= m; i++) { if (table[i]) prime.emplace_back(i); } return prime; } }; } // namespace ebi