-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathPRIME1.cpp
More file actions
45 lines (45 loc) · 1.09 KB
/
PRIME1.cpp
File metadata and controls
45 lines (45 loc) · 1.09 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
#include <bits/stdc++.h>
using namespace std;
int main(){
long long int i,j,t,m,n,k;
vector<bool> isPrime(100000,1);
for(i=2;i<=100000;i++){
if(isPrime[i]){
for(j=i*i;j<=100000;j+=i){
isPrime[j]=0;
}
}
}
vector<int> prime;
for(i=2;i<=isPrime.size();i++){
if(isPrime[i]){
prime.push_back(i);
}
}
cin>>t;
for(i=0;i<t;i++){
cin>>n>>m;
vector<bool> sieve(m-n+1,1);
for(j=0;prime[j]*(long long)prime[j] <= m;j++){
long long int curprime = prime[j];
long long int base = floor(n/curprime) * curprime;
if(base<n){
base= base + curprime;
}
for(k=base;k<=m;k+=curprime){
sieve[k-n]=0;
}
if(base==curprime){
sieve[base-n]=1;
}
if(n==1){
sieve[0]=0;
}
}
for(j=0;j<sieve.size();j++){
if(sieve[j]){
cout<<n+j<<endl;
}
}
}
}