Algoritma Dengan Java

advertisement
Algoritma Dengan Java
March 12th, 2010 | 3 Comments
1. Algoritma Sorting
Pengertian Algoritma Sorting adalah kumpulan langkah sistematis atau secara berutan untuk
memperoleh hasil yang diinginkan. Salah satu contoh dari algoritma untuk langkah ini adalah
Sorting (pengurutan). Sorting dapat didefinisikan sebagai pengurutan sejumlah data berdasarkan
nilai tertentu. Pengurutan dapat dilakukan dari nilai terkecil ke nilai terbesar (ascending) atau
sebaliknya.
Sorting dapat dibedakan menjadi dua yaitu Comparasion Sort (Bubble Sort, Selection Sort,
Insertion Sort, Merge Sort, Quick Sort) dan Non-Comparasion Sort (Radix Sort, Counting
Sort). Comparasion Sort / penggurutan dengan pembandingan adalah algoritma yang dalam
proses pengurutannya melakukan pembandingan antar data. Non-Comparasion Sort / pengurutan
tanpa pembandingan adalah algoritma pengurutan dimana dalam prosesnya tidak melakukan
perbandingan antar data.
1. Pengurutan Bilangan Metode Bubble Sort.
Proses pengurutannya adalah untuk mengurutkan bilangan diperlukan variable array untuk
menampung semua bilangan yang akan kita urutkan. Proses pengurutan dilakukan dengan
membangkan semua bagian array satu per satu. Contoh dibawah ini berisi sederer bilangan yang
belum diurutkan.
21
13
36
12
1
18
2
9
3
59
4
24
5
6
7
8
Indeks yang menunjukkan Posisi Elemen
Di metode Bubble Sort, proses pengurutan dimulai dengan membandingkan elemen pertama
untuk mendapatkan angka yang paling besar. Lalu angka terbesar tersebut ditempatkan pada
elemen terakhir. Sebagai langkah awal, isi elemen pertama dibandingkan dengan elemen ke-2.
Jika isi elemen ke-2 lebih kecil dari elemen pertama, maka isi kedua elemen tersebut ditukar.
Sehingga isi array akan berubah menjadi :
13
21
36
12
1
18
2
9
3
59
4
24
5
6
Elemen array telah ditukar
7
8
Lalu elemen ke-2 dibandingkan dengan elemen ke-3, jika isi element ke-3 lebih besar, maka isi
kedua elemen tersebut tidak ditukar.
13
21
36
12
1
18
2
9
3
59
24
4
5
6
7
8
Isi elemen ke-3 lebih besar dari elemen ke-2
Perbandingan selanjutnya dilakukan terhadap elemen ke-3 dengan ke-4. Karena elemen ke-4
lebih kecil, maka isi kedua elemen tersebut ditukar. Sehingga arrat sebelumnya berubah menjadi:
13
21
12
36
1
2
18
3
9
4
59
5
6
7
8
Isi elemen setelah ditukar
Proses perbandingan seperti diatas dilakukan secara berulang sampai pada elemen terakhir.
Sehingga pada akhirnya akan dihasilkan bilangan terbesar yang ditempatkan pada posisi elemen
terakhir. Dibawah ini kondisi array setelah perbandingan elemen terakhir.
13
21
12
36
1
2
18
3
9
4
24
5
6
59
7
8
Isi elemen terakhir berisikan bilangan terbesar
Proses diatas hanya mencari bilangan terbesar pertama. Ulangi proses tersebut untuk mencari
bilangan terbesar lainnya setelah bilangan terbesar pertama tadi. Namun proses perbandingan
hanya dilakukan mulai dari elemen pertama sampai elemen ke-7.
Isi elemen pertama dibandingkan dengan elemen ke-2. Karena isi elemen ke-2 lebih besar, maka
isi kedua elemen tersebut tidak ditukar.
Kemudian elemen ke-2, dibandingkan dengan elemen ke-3. Karena elemen ke-3 lebih kecil,
maka isi kedua elemen tersebut ditukar sehingga isi array menjadi :
13
12
21
18
1
9
2
36
3
24
4
59
5
6
7
8
Isi elemen array yang sudah diurut
Lanjutkan proses diatas sampai pada elemen ke-7. Hasilnya isi array menjadi :
13
12
18
9
1
21
2
24
3
36
4
59
5
6
7
8
Isi elemen array yang sudah diurut
Kini isi elemen ke-7 dan ke-8 sudah urut berdasarkan bilangan kecil ke besar. Namun elemen
lainnya belum terurut. Untuk itu ulangi proses diatas, namun elemen yang dibandingkan hanya
sampai pada elemen ke-6 saja. Setelah itu, proses perbadingan diulangi lagi sampai elemen
terakhir yang dibandingkan yaitu elemen ke-2. Hasil akhirnya menjadi :
9
12
13
18
1
21
2
24
3
Source Code pada Java
public class BubbleSort {
public static void main(String args[]){
int[] data={21,13,36,12,18,9,59,24};
int temp;
for (int i=1;i<data.length;i++){
for (int j=data.length-1;j>=i;j–){
if (data[j]<data[j-1]){
temp=data[j];
data[j]=data[j-1];
data[j-1]=temp;
}
}
}
for (int i=0;i<data.length;i++)
System.out.print(data[i]+” “);
36
4
59
5
6
7
8
}
}
2. Pengurutan Bilangan Metode Selection Sort.
Selection sort merupakan sebuah algoritma pengurutan yang secara berulang mencari item yang
belum terurut dan mencari paling sedikit satu untuk dimasukkan ke dalam lokasi akhir. Selection
sort salah satu agoritma pengurutan yang mudah untuk dipelajari. Dibandingkan dengan bubble
short, frekuensi pertukaran data pada selection short lebih sedikit.
Metode ini memiliki konsep memilih data yang maksimum/minimum dari suatu kumpulan data
larik L, lalu menempatkan data tersebut ke elemen paling akhir atau paling awal sesuai
pengurutan yang diinginkan. Data maksimum/minimum yang diperoleh, diasingkan ke tempat
lain, dan tidak diikutsertakan pada proses pencarian data maksimum/minimum berikutnya. Ide
utama dari selection short adalah memiliki elemen dengan nilai paling rendah dan menukar
elemen yang terpilih dengan elemen ke-1. Nilai dari I dimulai dari 1 ke n, dimana n adalah
jumlah total elemen dikurangi 1.
Prinsip kerja dari Teknik Section sort ini adalah:
1. Pengecekan dimulai dari data 1 sampai dengan data ke n
2. Tentukan bilangan dengan Index terkecil dari data bilangn tersebut
3. Tukar bilangan dengan index terkecil tersebut dengan bilangan pertama (I=1) dari
data bilangan tersebut
4. Lakukan langkah 2 dan3 untuk bilangan berikutnya (I=I+1)sampai di dapatkan data yang
optimal
Sintaks program fungsi Selection Sort
for ( i=0 ; i <= N-2 ; i++) { kecil = i; for ( k = i+1 ; k <= N-1 ; k++ ) { if (A[k] > A[j])
{
kecil = k;
}
}
temp = A[i];
A[i] = A[kecil];
A[kecil] = temp;
}
Contoh kasus:
Misalkan tabel A berisi elemen-elemen berikut:
15, 100, 136, 12, 18,19, 59, 24, 10, 191
Langkah-langkah pengurutan dengan Selection Sort:
Contoh Ilustrasi: Urutkan data berikut 15, 100, 136, 12, 18,19, 59, 24, 10, 191
Contoh program Java 1:
public class SelectionSort{
public static void main(String args[]){
int[] data={15, 100, 136, 12, 18,19, 59, 24, 10, 191};
int temp,pos;
for (int i=0;i<data.length-1;i++){
pos=i;
for (int j=i+1;j<data.length;j++){
if (data[j]<data[pos]){
pos=j;
}
}
if (pos!=i){
temp=data[i];
data[i]=data[pos];
data[pos]=temp;
}
}
for (int i=0;i<data.length;i++)
System.out.print(data[i]+” “);
}
}
Contoh program Java 2 :
public class SelectionSort {
public static void main(String[] args)
{ int[] x = {15, 100, 136, 12, 18,19, 59, 24, 10, 191};
int i, temp, j;
System.out.println(“Sebelum diurutkan :”);
for(i=0;i<x.length;i++)
System.out.print(x[i]+”\t”);
System.out.println(“\n”);
for(i=0;i<x.length-1;i++)
{ for(j=i+1;j<x.length;j++)
{ if(x[i]>x[j])
{ temp = x[i];
x[i] = x[j];
x[j] = temp;
}
}
for(int k=0;k<x.length;k++)
System.out.print(x[k]+”\t”);
System.out.println();
}
System.out.println(“Setelah diurutkan :”);
for(i=0;i<x.length;i++)
System.out.print(x[i]+”\t”);
}
}
Bersambung..!!!
while dan do ... while
Posted Sen, 02/16/2009 - 23:51 by belajarprogram
Versi ramah cetak
Pernyataan while
Pernyataan while telah diperkenalkan pada bagian sebelumnya. Perulangan while memiliki
bentuk
while (suatu_kondisi)
perintah
perintah bisa juga berupa blok yang berisi kumpulan perintah-perintah di antara { dan }.
perintah ini disebut juga dengan inti perulangan. Inti perulangan akan terus dieksekusi selama
suatu_kondisi bernilai true. suatu_kondisi ini disebut juga penguji perulangan.
Ada beberapa hal yang mungkin jadi pertanyaan. Apa yang terjadi jika suatu_kondisi sudah
bernilai false sejak pertama kali komputer sampai pada pernyataan ini? Dalam hal ini blok
perulangan tidak akan dieksekusi sama sekali. Program akan melompat ke perintah berikutnya di
luar blok perulangan.
Lalu apa yang terjadi jika suatu_kondisi bernilai false di tengah-tengah perulangan, apakah
program keluar dari perulangan saat itu juga? Dalam hal ini, tentunya tidak. Program akan
mengeksekusi semua perintah hingga akhir blok selesai. Setelah itu program akan kembali ke
pernyataan while, dan setelah mengevaluasi kembali suatu_kondisi, dan jika hasilnya salah,
baru program akan melompat ke perintah berikutnya di luar blok.
Mari kita ubah sedikit algoritma yang kita buat di bagian sebelumnya. Kali ini kita akan
membuat program yang menghitung rata-rata dengan cara menanyakan suatu bilangan kepada
user, kemudian program akan berhenti jika masih ada data yang akan diproses.
Inisialisasi jumlah dengan 0
Inisialisasi n (berapa data yang dimasukkan user) dengan 0
while (masih ada data yang akan diproses):
Minta input dari user
Tambah jumlah dengan input dari user
Tambah n dengan 1
Bagi jumlah dengan n untuk menghitung rata-rata
Cetak rata-rata ke layar
Pertanyaan berikutnya, bagaimana menentukan masih ada data yang akan diproses? Cara yang
paling mudah adalah melihat apakah nilai yang dimasukkan user bernilai 0. Nol di sini bukan
termasuk data yang akan dijumlahkan tetapi bertugas sebagai sinyal bahwa tidak ada lagi data
yang harus dimasukkan.
Lalu bagaimana kita harus menguji bahwa data yang dimasukkan bernilai 0 atau bukan? (Ingat,
kita baru menanyakan data di dalam blok perulangan. Pada saat komputer pertama kali menemui
perulangan while, komputer tidak tahu apa-apa.) Dalam hal ini, kita akan sedikit ubah algoritma
kita seperti berikut :
Inisialisasi jumlah dengan 0
Inisialisasi n (berapa data yang dimasukkan user) dengan 0
Minta input dari user
while (input tidak sama dengan 0):
Tambah jumlah dengan input dari user
Tambah n dengan 1
Minta input dari user
Bagi jumlah dengan n untuk menghitung rata-rata
Cetak rata-rata ke layar
Pada dasarnya, kita tanyakan user terlebih dahulu sebelum perulangan while. Dengan cara ini,
kita bisa mendapat nilai input untuk dievaluasi pada pernyataan while. Di dalam perulangan
while, kita tempatkan pertanyaan untuk mendapat input dari user di akhir perulangan. Artinya,
setelah kita memproses input dari user, kita akan tanyakan lagi kepada user untuk mendapatkan
kondisi untuk mengevaluasi kondisi while berikutnya.
Perhatikan juga bahwa ketika 0 dimasukkan, program tidak akan menghitung nilai 0 lagi. Di
algoritma sebelumnya, nilai 0 akan ikut dijumlahkan dan n akan bertambah 1, padahal 0 bukan
data. Nol hanya berfungsi sebagai sinyal bahwa perulangan harus selesai. Masalah ini sangat
amat umum ditemui oleh programmer, karena menghitung satu demi satu ternyata tidak mudah.
Untuk itu debugger diperlukan untuk melihat lebih detail apa yang dilakukan oleh komputer.
Kita bisa ubah algoritma di atas menjadi program Java sebagai berikut. (Seperti biasa program
ini bisa diunduh dalam bentuk zip file atau di alamat SVN berikut:
http://belajarjava.googlecode.com/svn/trunk/RataRata )
package ratarata;
import java.io.*;
public class RataRata {
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
double jumlah = 0;
double bilangan = 0;
int n = 0;
BufferedReader br = new BufferedReader(new
InputStreamReader(System.in));
String strbilangan = null;
System.out.print("Masukkan bilangan pertama : ");
try {
strbilangan = br.readLine();
} catch (IOException ioe) {
System.out.println("Kesalahan IO, program berhenti");
System.exit(1);
}
// mengubah input menjadi double agar bisa diproses lebih
lanjut
bilangan = Double.parseDouble(strbilangan);
while (bilangan != 0) {
jumlah += bilangan;
// sama dengan : jumlah = jumlah
+ bilangan
n++;
// sama dengan : n = n+1
// tanya user input
System.out.print("Masukkan bilangan berikutnya (atau 0
untuk mengakhiri) : ");
try {
strbilangan = br.readLine();
} catch (IOException ioe) {
System.out.println("Kesalahan IO, program berhenti");
System.exit(1);
}
// mengubah input menjadi double agar bisa diproses lebih
lanjut
bilangan = Double.parseDouble(strbilangan);
}
// hitung rata-rata
double ratarata = jumlah/n;
// cetak hasilnya ke layar
if (n == 0) {
System.out.println("Data kosong, rata-rata tidak bisa
dihitung");
} else {
System.out.println("Anda memasukkan " + n + " data");
System.out.println("Rata-rata bilangan yang dimasukkan
adalah " + ratarata);
}
}
}
Berikut hasil keluarannya :
Pernyataan do ... while
Kadang-kadang akan lebih mudah menulis perulangan jika penguji perulangan dilakukan di
akhir badan perulangan. Dalam hal ini badan perulangan akan dieksekusi terlebih dahulu tanpa
memperdulikan apakah suatu kondisi bernilai true atau false. Pengujian dilakukan di akhir
setelah suatu kondisi didapat dalam eksekusi perulangan pertama kali.
Pernyataan do ... while pada dasarnya merupakan pernyataan while terbalik, dengan bentuk.
do
perintah
while (suatu_kondisi);
Atau apabila perintah berbentuk blok kumpulan perintah-perintah, bisa juga ditulis dalam bentuk
do {
perintah-perintah
} while (suatu_kondisi);
Perlu diingat bahwa pernyataan do ... while diakhiri dengan tanda ; di akhir while.
Contoh sederhana adalah program bermain game, di mana game akan menanyakan apakah user
ingin bermain lagi.
do {
main game
tanya user apakah ingin main lagi
} while (user menjawab ya);
Jika suatu saat Anda harus menulis kondisi pada pernyataan while seperti ini while (jawaban
== true), Anda bisa mengganti pernyataan ini menjadi while (jawaban). Menguji apakah
jawaban sama dengan true sama artinya dengan melihat apakah jawaban berisi "true".
Demikian juga dengan while (jawaban == false), bisa diganti dengan while (!jawaban).
Seperti dijelaskan pada bab tentang operator boolean, operator ! membalik isi dari boolean,
misalnya dari true menjadi false atau sebaliknya. Dengan menuliskan while (!jawaban) berarti
sama dengan menguji apakah jawaban berisi false.
Pernyataan do ... while memberikan keleluasaan kepada Anda untuk berekspresi dengan
lebih lugas. Sebenarnya, untuk memecahkan suatu masalah dengan perulangan do ... while
juga bisa diekspresikan dengan perintah while, demikian juga sebaliknya.
do
perintah
while (suatu_kondisi);
bisa dituliskan dalam bentuk
perintah
while (suatu_kondisi)
perintah
Demikian juga dengan
while (suatu_kondisi)
perintah
bisa juga dituliskan dalam bentuk
if (suatu_kondisi) {
do {
perintah
while (suatu_kondisi);
}
tanpa merubah aliran program sama sekali.
Pernyataan break dan continue
Pernyataan while dan do ... while menguji kondisi di awal atau di akhir badan perulangan.
Pengujian bisa juga dilakukan di tengah-tengah badan perulangan, kemudian memerintahkan
program untuk keluar dari badan perulangan saat itu juga. Caranya dengan menggunakan
perintah
break<code>, sehingga program seperti
<code>while (suatu_kondisi)
perintah
bisa ditulis dalam bentuk
while (true)
perintah
if (!suatu_kondisi)
break;
<code>
Apa makna dari program di atas? <code>while (true)
artinya memerintahkan program untuk melakukan perulangan selamanya, karena true tidak akan
berubah. Di tengah-tengah program, kita uji apakah suatu_kondisi bernilai false. Jika ya, maka
perintah break akan dieksekusi yang menyebabkan program keluar dari badan perulangan ke
perintah berikutnya di luar badan perulangan.
Kadang-kadang gaya penulisan ini lebih masuk akal ketimbang gaya penulisan baku seperti
while atau do ... while, tapi tentu saja ini tergantung dari cara pikir masing-masing
programmer dan juga masalah yang akan dipecahkan.
Pernyataan while atau do ... while dapat dibuat bertingkat, misalnya membuat blok while
dalam blok while.
while (suatu_kondisi) {
perintah
while (kondisi_lain) {
perintah_lain
while (kondisi_lain_lagi) {
perintah_baru
}
}
}
Apabila perintah break diberikan, maka program akan keluar dari perulangan yang berada persis
di atasnya. Misalnya, apabila perintah break diberikan setelah perintah_lain maka program
akan keluar dari dalam perulangan while (kondisi_lain).
Perlu diingan juga apabila perintah break diberikan di dalam pernyataan if, maka program akan
keluar dari perulangan yang persis di atasnya.
Selain perintah break yang secara langsung menghentikan perulangan, perintah continue
digunakan untuk menghentikan operasi saat itu, mengabaikan perintah hingga perulangan
berakhir, kemudian kembali kepada perintah while lagi. Misalnya,
while (suatu_kondisi) {
perintah
continue;
perintah_lagi
perintah_lain_lagi
}
Perulangan akan menjalankan perintah, mengabaikan perintah_lagi dan
perintah_lain_lagi, kemudian kembali kepada pernyataan while untuk mengevaluasi apakah
suatu_kondisi bernilai true. Jika ya perulangan akan diteruskan. Tetapi karena ada perintah
continue, artinya selama perulangan tersebut berjalan, perintah_lagi dan
perintah_lain_lagi tidak akan pernah dieksekusi.
Download