forked from HarshCasper/NeoAlgo
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathSieve_of_Eratosthenes.c
57 lines (49 loc) · 1.48 KB
/
Sieve_of_Eratosthenes.c
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
46
47
48
49
50
51
52
53
54
55
56
57
/*Sieve_of_eratosthenes
Sieve of Eratosthenes is an ancient algorithm for finding all prime numbers up to any given limit.
It does so by iteratively marking as composite (i.e., not prime) the multiples of each prime, starting with
the first prime number, 2. The multiples of a given prime are generated as a sequence of numbers starting from that prime,
with constant difference between them that is equal to that prime.*/
//Header files
#include <stdio.h>
#include <stdlib.h>
void Sieve_of_eratosthenes(int n)
{
// Creating an array for storing prime factors.
// and if the i is not prime, mark it as 0 else 1
int prime[n + 1];
// Initialising all elements as 1
for(int i = 2; i <= n; i++)
prime[i] = 1;
for(int i = 2; i * i <= n; i++)
{
// If prime[i] is marked 1, then it is a prime.
if(prime[i] == 1)
{
// Marking all multiples of i as 0
for(int j = i * i; j <= n; j += i)
prime[j] = 0;
}
}
// Printing all the prime numbers
for(int i = 2; i <= n; i++)
if(prime[i])
{
printf("%d ", i);
}
}
// Driver Function
int main()
{
int num;
printf("Enter the number: \n");
scanf("%d", &num);
printf("The prime numbers smaller than or equal to %d are: \n", num);
Sieve_of_eratosthenes(num);
return 0;
}
/*Sample Input:
Enter the number: 10
Sample Outut:
The prime numbers smaller than or equal to 10 are:
2 3 5 7
*/