/* Bismillahir Rahmanir Rahim
Segmented Sieve-Prime number in big range (10^14).
Given two number (10^14) and given all primes in range.
First execute all the primes bellow sqrt(b).
*/
#include<bits/stdc++.h>
#define ll long long
using namespace std;
ll t, a, b, p, st, i, j, k;
bool prime[10000007], ar[1000006];
void primes(ll x){ // mind, 2 is prime
for(ll i=3; i*i<=x; i+=2){
if(prime[i]){
for(ll j=i*3; j<=x; j+=i*2) prime[j]=false;
}
}
}
int main(){
while(cin>>a>>b){
p=sqrt(b+1);
for(i=0; i<=p; i++) prime[i]=true;
for(i=0; i<=(b-a); i++) ar[i]=true;
primes(p);
for(i=3; i<=p; i+=2){// we don't execute the even number
if(prime[i]){
st=a;
if(st%i) st=a+(i-(st%i)); // use i not ar[i]
if(st==i) st=st*2; //if the first number is prime
for(k=st; k<=b; k+=i) ar[k-a]=false;
}
}
if(a==2) cout<<2<<" "; // special case
st=0;
if(a%2==0) st=1; // its for skipping even number
for(i=st; i<=(b-a); i+=2){ //we don't touch even number
if(ar[i]) cout<<i+a<<" ";
}
cout<<endl;
}
return 0;
}
/*
Input:
100000000000000 100000000100000
Output:
(big output, to see run the code)
*/
|
Monday, March 20, 2017
Segmented Sieve-All Primes in Range
Subscribe to:
Post Comments (Atom)
-
#include<bits/stdc++.h> #define ll long long using namespace std ; ll n , k , t_case ; ll bigmod ( ll b , ll p , ll m...
-
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 3...
-
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 ...
No comments:
Post a Comment