Home » » Saringan Eratosthenes

Saringan Eratosthenes

Posted by KEPOIN IT on Monday, November 7, 2011


Saringan Eratosthenes adalah suatu cara untuk menemukan semua bilangan prima di antara 1 dan suatu angka n. Saringan ini ditemukan oleh Eratosthenes, seorang ilmuwan Yunani kuno. Cara ini merupakan cara paling sederhana dan paling cepat untuk menemukan bilangan prima, sebelum Saringan Atkin ditemukan pada tahun 2004. Saringan Atkin merupakan cara yang lebih cepat namun lebih rumit dibandingkan dengan Saringan Eratosthenes.

[sunting] Langkah-langkah saringan Eratothenes

Misalkan kita hendak menemukan semua bilangan prima di antara 1 sampai suatu bilangan bulat n.
  1. Tulis semua bilangan, mulai dari 1 sampai n. Misalkan ini adalah daftar A.
  2. Buat suatu daftar yang masih kosong, sebut saja daftar B.
  3. Coret bilangan 1 dari daftar A.
  4. Lalu tulis 2 pada daftar B. Lalu coret 2 dan semua kelipatannya dari daftar A
  5. Bilangan pertama yang belum tercoret dari daftar A (misalnya 3) adalah bilangan prima. Tulis bilangan ini di daftar B, lalu coret bilangan ini dan semua kelipatannya dari daftar A.
  6. Ulangi langkah 4 sampai semua bilangan di daftar A sudah tercoret.
Setelah selesai, semua bilangan di daftar B adalah bilangan prima.

[sunting] Saringan Eratosthenes dan pemrograman

Saringan Eratosthenes dapat dimanfaatkan dalam pemrograman. Sebuah program dapat menampilkan deretan bilangan prima yang ada di antara 1 sampai n dengan memanfaatkan ide saringan Eratosthenes. Berikut ini adalah sebuah potongan kode dalam bahasa pemrograman Java yang mencetak bilangan prima di antara 1 sampai n=120.
int n=120; //batas atas n dapat diganti dengan bilangan bulat lainnya
boolean[] prima=new boolean[n+1];
 
for(int i=0; i<=n; i++)
        prima[i]=true;        //set seluruh array menjadi true
prima[0]=prima[1]=false;     //0 dan 1 bukan bil. prima
double akarN=Math.sqrt(n);      //akar kuadrat dari n
 
//coret bilangan yang bukan prima
for(int i=2; i<=akarN; i++) {
        if (prima[i]) {
             for (int j=i*i; j<=n; j=j+i)
                 prima[j]=false;
        }
}
 
//tampilkan seluruh bilangan prima
for(int i=0; i<n; i++) {
        if (prima[i])
                System.out.print(i+ "\t"); 
}

 Berikut ini algoritma tersebut yang dikutip dari Wikipedia.
Misalkan kita hendak menemukan semua bilangan prima di antara 1 sampai suatu bilangan bulat n.
  1. Tulis semua bilangan, mulai dari 1 sampai n. Misalkan ini adalah daftar A.
  2. Buat suatu daftar yang masih kosong, sebut saja daftar B.
  3. Coret bilangan 1 dari daftar A.
  4. Lalu tulis 2 pada daftar B. Lalu coret 2 dan semua kelipatannya dari daftar A
  5. Bilangan pertama yang belum tercoret dari daftar A (misalnya 3) adalah bilangan prima. Tulis bilangan ini di daftar B, lalu coret bilangan ini dan semua kelipatannya dari daftar A.
  6. Ulangi langkah 4 sampai semua bilangan di daftar A sudah tercoret.
Setelah selesai, semua bilangan di daftar B adalah bilangan prima.
Dan berikut ini contoh penerapan algoritma di atas dalam bahasa pemrograman PHP. Script ini sudah ditest untuk menampilkan bilangan prima dibawah 1.000.000 dan berhasil menampilkannya dalam waktu 3 detik.
http://achmatim.net/wp-content/plugins/wp-synhighlight/themes/default/images/code.png http://achmatim.net/wp-content/plugins/wp-synhighlight/themes/default/images/printer.png http://achmatim.net/wp-content/plugins/wp-synhighlight/themes/default/images/info.gif 
1.  <?php
2.   
3.  function bilangan_prima($limit) {
4.    $prima = array();
5.    $prima_awal = array(2,3,5,7);
6.   
7.    for ($i=2; $i<=$limit; $i++)
8.           $prima[$i] = true;
9.   
10.  foreach ($prima_awal as $awal) {
11.         for ($i=2*$awal; $i<=$limit; $i+=$awal) {
12.                 $prima[$i] = false;
13.         }
14.  }
15. 
16.  foreach ($prima as $bilangan=>$status) {
17.         if ($status) echo "$bilangan ";
18.  }
19.}
20.$start=mktime();
21. 
22.bilangan_prima(1000000);
23. 
24.$finish=mktime();
25.$result=$finish-$start;
26.echo "<br>Time: $result seconds";
27. 
28.?>

Thanks for reading & sharing KEPOIN IT

Previous
« Prev Post

0 comments:

Post a Comment

Cari Artikel

Paling Dilihat