#include #include #ifdef LOCAL #include #define debug(...) debug_print::multi_print(#__VA_ARGS__, __VA_ARGS__) #else #define debug(...) (static_cast(0)) #endif using namespace atcoder; using mint=modint998244353; using namespace std; using ll=long long; using ul=unsigned long long; int dx[9] = {-1, 1, 0, 0, -1, -1, 1, 1, 0}; int dy[9] = {0, 0, -1, 1, -1, 1, -1, 1, 0}; using Graph=vector>; ll op(ll a,ll b){return min(a,b);} ll e(){return 2e9;} vector erat(int Max){ vectorans; vectorcheck(Max+1); for(int i=2;i<=Max;i++){ if(check[i])continue; else{ ans.push_back(i); for(int j=i*2;j<=Max;j+=i)check[j]=1; } } return ans; } int main(){ int N; cin>>N; int cnt=0; vectorA=erat(N); for(int i=0;i