ANALISIS PERBANDINGAN ALGORITMA DENGAN DENGAN M E RGE SEL ECTI ON SOR SORT T RGE SOR SORT T Disusun untuk memenuhi tugas UTS mata mata kuliah : Analisis Algoritma
Oleh : Eka Risky Firmansyah 1110091000043
Program Studi Teknik Informatika Fakultas Sains dan Teknologi Universitas Islam Negeri Syarif Hidayatullah Jakarta 2012
DAFTAR ISI
DAFTAR ISI ............................... ................................................. ................................... .................................. ................................... .................................. .................. .. 1 KATA PENGANTAR ................................... .................................................... .................................. .................................. ................................... .................... 2 BAB I PENDAHULUAN ................................. ................................................. .................................. ................................... ................................. ................ 3
1. LATAR BELAKANG ................................... ................................................... .................................. ................................... ................................. ................ 3 ................................................ ................................... ................................... ................................. ................ 3 2. METODE PENULISAN ...............................
3. TUJUAN PENULISAN ................................. ................................................. .................................. ................................... ................................. ................ 3 4. MANFAAT PENULISAN ................................. .................................................. .................................. .................................. .............................. ............. 3 BAB II LANDASAN TEORI ................................. ................................................. .................................. ................................... ........................... .......... 4 ................................................... ................................... ................................... ..................... .... 4 1. ALGORITMA PENGURUTAN ..................................
2. K OMPLEKSITAS ................................................... ................................... .................................. .................. .. 5 OMPLEKSITAS ALGORITMA .................................. ................................................. .................................. ................................... ................................. ................ 5 3. GROWTH FUNCTION ................................. ................................................ ................................... ................................... ................................. ................ 6 4. N 4. NOTASI ASIMPTOTIK ...............................
BAB III PEMBAHASAN ................................. ................................................. .................................. ................................... ................................. ................ 7
1. S ELECTION .................................................. ................................... .................................. .................................. ...................... .... 7 ELECTION S ORT ORT ................................. ................................................... .................................. ........................... .......... 7 Penjelasan Singkat Selection Sort ..................................
Pseudocode Minimum Selection Sort ................................... ................................................... .................................. ...................... .... 7 Pseudocode Maximum Selection Sort ................................... ................................................... .................................. ...................... .... 8 .................................................. ................................... .................... 8 Loop Invariant Minimum Selection Sort .................................
Simulasi Algoritma Pengurutan Seleksi (Selection Sort) ................................ ............................................. ............. 9 Analisis dan Running Time Selection Sort ................................. .................................................. ............................... .............. 10 2. M 2. M ERGE S ORT ................................................. ................................. .................................. ................................... .......................... ........ 12 ORT ................................. ................................................. ................................... ............................... .............. 12 Penjelasan Singkat Merge Sort ...............................
Rekurensi (Reccurence) ................................... ................................................... .................................. .................................. ...................... ...... 12 Divide and Conquer ............................... ................................................ ................................... ................................... ............................... .............. 12 ................................................... .................................. .................................. ...................... ...... 12 Pseudocode Merge Sort ...................................
Loop Invariant pada Prosedur Prosedur Merge .................................. .................................................. .................................. .................... .. 13 Simulasi Algoritma Merge Sort ............................... ................................................. ................................... ............................... .............. 14 ................................................... .................................. ................. 19 Analisis dan Running Time Merge Sort ..................................
............................. 20 3. A NALISIS PERBANDINGAN S ELECTION ELECTION S ORT ORT DENGAN DENGAN M ERGE S ORT ORT ..............................
BAB IV KESIMPULAN & SARAN ................................. .................................................. .................................. ............................... .............. 22
1. K ESIMPULAN ................................................. ................................. .................................. ................................... .......................... ........ 22 ESIMPULAN ................................. .................................................. .................................. .................................. ................................... .................................. ................ 22 2. SARAN .................................
DAFTAR PUSTAKA ................................. .................................................. ................................... .................................. .................................. .................... .. 23
1
KATA PENGANTAR
Bismillahirrahmanirrahiim. Assalamualaikum, wr. wb. wb. Puji dan syukur penulis panjatkan kepada Allah SWT, shalawat serta salam semoga senantiasa dilimpahkan kepada Nabi Muhammad SAW, juga untuk para keluarga, sahabat dan pengikutnya sampai akhir zaman. Karena atas rahmat-Nya, penulis dapat menyelesaikan karya tulis ini yang berjudul “Analisis “ Analisis Perbandingan Algoritma Selection Sort dengan Merge Sort”. Sort”. Karya tulis ini dibuat untuk memenuhi tugas Ujian Tengah Semester Genap dari mata kuliah Analisis Algoritma. Penulis ingin mengucapkan terima kasih kepada Ibu Ria Hari Gusmita, ST., M.Kom. selaku dosen pengampu, teman-teman dan semua pihak yang membantu dalam penyelesaian karya tulis ini. Penulis juga menyadari jika karya tulis ini masih jauh dari kesempurnaan dan terdapat banyak kekurangan. Untuk itu penulis mengharapkan kritik, koreksi dan saran dari semua pembaca dalam penyempurnaan karya tulis ini. Semoga karya tulis ini bermanfaat bagi pembaca, khususnya bagi penulis mengenai pemahaman analisis a nalisis algoritma. Penulis menghaturkan permohon per mohonan an maaf jika masih ter dapat kekurangan dalam karya tulis ini. Wassalamualaikum, wr. wb. wb .
Penulis
2
BAB I PENDAHULUAN
1. Latar Belakang Dalam pembuatan sebuah aplikasi seringkali kita membutuhkan sebuah algoritma yang dapat digunakan untuk melakukan pengurutan data, baik data yang berupa bilangan, karakter dan string . Algoritma yang digunakan tersebut selain harus menghasilkan data yang benar, juga harus efektif dan efisien. Namun ada hal lain yang harus dipertimbangkan, misalnya jumlah data yang akan diurutkan. Jika hanya sedikit data yang akan diurutkan maka perbedaan antar algoritma pengurutan tidak terlalu berpengaruh, sebaliknya jika terdapat banyak data yang akan diurutkan maka akan terlihat perbedaan dan keunggulan suatu algoritma, terutama dalam hal kecepatan dan pemakaian jumlah memori. memori. Untuk itulah dalam karya tulis ini akan dibahas mengenai dua buah algoritma pengurutan yaitu algoritma a lgoritma pengurutan seleksi ( selection sort ) dan algoritma pengurutan merge ( merge (merge merge sort ) dengan analisis dan perbandingan kompleksitasnya.
2. Metode Penulisan Penulisan karya tulis ini menggunakan metode pustaka terutama dengan sumber atau referensi dari internet dan analisis dari penulis.
3. Tujuan Penulisan Penulisan karya tulis ini bertujuan sebagai berikut :
Memenuhi nilai tugas UTS mata kuliah Analisis Algoritma yang diampu oleh ibu Ria Hari Gusmita, ST., M.Kom.
Menambah pengetahuan penulis mengenai analisis algoritma terutama algoritma pengurutan yang dibahas dibahas di karya tulis ini.
4. Manfaat Penulisan Penulis berharap semoga karya tulis ini dapat menambah pemahaman bagi pembaca dan penulis mengenai analisis algoritma.
3
BAB II LANDASAN TEORI
1. Algoritma Pengurutan Algoritma merupakan urutan aksi-aksi yang dinyatakan dengan jelas dan tidak rancu untuk memecahkan suatu masalah dalam rentang waktu tertentu. Sedangkan pengurutan adalah proses pengaturan sekumpulan objek berdasarkan urutan atau susunan tertentu, dapat berupa pengurutan menaik (ascending ( ascending ) atau menurun (descending ( descending ). ). Contoh, sebuah larik atau array terdiri array terdiri dari dar i kumpulan bilangan : [3,12,1,50,33 [ 3,12,1,50,33,5,28] ,5,28]
Hasil pengurutan menaik (ascending ( ascending ) : [1,3,5,12,28,33,50] [1,3,5,12,28,33,50]
Hasil pengurutan menurun (descending ( descending ) : [50,33,28,12,5,3,1] [50,33,28,12,5,3,1] Sebuah algoritma dikatakan baik jika menghasilkan nilai yang benar, efektif dan
efisien. Efektif yaitu tepat sasaran, jelas dan tidak rancu dalam menjalankan aksi-aksinya serta menghasilkan data yang benar. Efisien yaitu penghematan proses dari sebuah algoritma, seperti running time dan time dan penggunaan memori. Metode atau algoritma pengurutan dapat diklasifikasikan menjadi : 1.
Metode atau algoritma pengurutan internal, yaitu pengurutan yang dilakukan di dalam larik itu sendiri. Datanya Dat anya disimpan di dalam memori komputer. komputer.
2.
Metode atau algoritma pengurutan eksternal, yaitu pengurutan yang datanya disimpan di dalam disk storage. storage. Metode ini disebut juga pengurutan arsip. Sedangkan berdasarkan kestabilan ( stability), stability), algoritma pengurutan dapat dibagi menjadi dua jenis, yaitu :
1. Metode pengurutan stabil ( stable sorting algorithm), algorithm), merupakan algoritma pengurutan yang menjaga/mempertahankan ( maintenance) maintenance) urutan dari beberapa elemen array yang array yang bernilai sama. 2. Metode pengurutan tidak stabil (non ( non stable sorting algorithm), algorithm ), merupakan metode pengurutan yang tidak menjaga/mempertahankan ( maintenance) maintenance) urutan dari beberapa elemen array array yang bernilai sama. Dengan kata lain, urutan beberapa elemen yang sama berbeda antara sebelum dan sesudah pe ngurutan. Algoritma memiliki dua skema, yaitu iteratif dan rekursif. Iteratif yaitu algoritma yang melakukan perulangan biasa, sedangkan rekursif adalah algoritma yang melakukan perulangan dengan melakukan pemanggilan terhadap dirinya sendiri. Contoh algoritma pengurutan yang termasuk dalam skema iteratif, yaitu pengurutan apung ( bubble sort ), ), 4
pengurutan seleksi ( selection sort so rt ), ), pengurutan sisipan (insertion ( insertion sort ), shell ), shell ( ( shell sort ). ). Contoh algoritma pengurutan yang termasuk dalam skema rekursif, yaitu pengurutan merge (merge sort ), ), pengurutan heap (heap sort ) dan pengurutan cepat (quick ( quick sort ). ). Tidak semua algoritma tersebut hanya memiliki satu skema, misalnya algoritma pengurutan seleksi atau selection sort yang dapat menggunakan skema rekursif, namun di dalam karya tulis t ulis ini selection ini selection sort yang dibahas menggunakan menggunakan skema iteratif. iterat if.
2. Kompleksitas Algoritma Efisiensi sebuah algoritma tergantung dari beberapa hal, diantaranya adalah :
Kinerja CPU
Kinerja Memori
Kinerja Disk
Kinerja Jaringan Algoritma memiliki kompleksitas, kompleksitas merupakan acuan utama utama
untuk mengetahui kecepatan dari sebuah algoritma. Kompleksitas dibagi menjadi tiga, yaitu : 1. Best case (Ω), (Ω), yaitu kompleksitas algoritma dimana algoritma tersebut berjalan dalam kondisi terbaik. 2. Average case (Θ), (Θ), yaitu kompleksitas algoritma dimana algoritma tersebut berjalan dalam kondisi sedang, biasanya inputnya secara acak. 3. Worst case (Ο), (Ο), yaitu kompleksitas algoritma dimana algoritma tersebut berjalan dalam kondisi terburuk.
3. Growth Function Kinerja sebuah algoritma biasanya di ukur dengan mengacu pada kondisi terburuknya, yaitu worst case case yang dilambangkan dengan notasi Big O. Notasi Big O adalah fungsi yang berkaitan dengan kelajuan proses dan kelajuan pertambahan data. Notasi
Nama Nama
O(1)
Konstan
O(log * n)
Iterasi logaritmik
O(log n)
Logaritmik
O((log n)c)
Polilogaritmik
O(n)
Linear
Contoh Aplikasi Menentukan apakah suatu bilangan ganjil atau genap Algoritma pencarian Hopcraft dan Ullman untuk himpunan disjoint Pencarian dalam list terurut t erurut dengan Binary dengan Binary Search Algorithm Menentukan bilangan prima dengan AKS dengan AKS primality test Pencarian dalam list tidak terurut 5
O(n log n) O(n )
Linearitmik Kuadratik
c
Poliomial
O(c )
n
Eksponensial
O(n!)
Faktorial
O(n ), c > 1
cn
O(2 )
Dobel Eksponensial
Mengurutkan list dengan Heapsort Mengurutkan list dengan Insertion Sort Pencarian shortest Pencarian shortest path dengan algoritma Floydalgoritma FloydWarshall Pencarian solusi untuk traveling salesman problem Menyelesaikan traveling salesman problem dengan menggunakan brute force Pencarian himpunan lengkap dari AC-unifiers (associative-commutative unifiers)
4. Notasi Asimptotik Notasi asimptotik digunakan untuk menentukan kompleksitas suatu algoritma dengan melihat waktu tempuh (running ( running time) time) sebuah algoritma. Waktu tempuh algoritma merupakan fungsi : N → R +. Notasi asimptotik memungkinkan untuk membandingkan suatu algoritma algoritma dengan algoritma lainnya. Notasi asimptotik dapat dituliskan dituliskan dengan dengan beberapa simbol, yaitu :
Notasi Big O, yaitu notasi asimptotik sebuah fungsi fungsi algoritma untuk batas atas.
Notasi Little o, yaitu yaitu notasi asimptotik sebuah fungsi algoritma untuk batas atas namun tidak secara ketat terikat (not (not asymptotically tight ). ).
Notasi Theta (), yaitu notasi asimptotik sebuah fungsi algoritma untuk batas atas dan bawah.
Notasi Similaritas/Tilda (~), yaitu notasi asimptotik yang digunakan untuk membandingkan level of performance dua performance dua buah fungsi algoritma.
Notasi Omega ( ), yaitu notasi asimptotik sebuah fungsi algoritma untuk batas bawah, notasi ini berlawanan dengan notasi notasi little-o. litt le-o.
6
BAB III PEMBAHASAN
1. Sel Sel ecti on Sor Sor t Penjelasan Penjelasan Singkat Sel Sel ection Sor Sor t Algoritma pengurutan seleksi atau selection sort merupakan kombinasi antara
sorting dan searching dan searching . Konsep dari atau selection atau selection sort yaitu yaitu dengan memilih elemen larik yang memiliki nilai paling besar atau paling kecil, lalu menempatkannya pada posisi awal atau akhir elemen larik (array (array). ). Lalu elemen terujung pada larik diisolasi. Proses tersebut dilakukan sebanyak n-1 (jumlah elemen lar ik dikurang dikurang 1). Algoritma pengurutan seleksi atau selection sort dapat menggunakan skema iteratif (perulangan biasa) maupun skema rekursif (perulangan dengan memanggil dirinya sendiri). Namun kali ini kita hanya akan membahas algoritma pengurutan seleksi atau selection sort yang menggunakan menggunakan skema iteratif. iterat if. Algoritma pengurutan seleksi atau selection atau selection sort dibagi menjadi dua, yaitu : 1. Algoritma pengurutan seleksi minimum atau minimum selection sort Yaitu dengan mencari nilai terkecil dari array dan array dan digunakan sebagai pembanding. 2. Algoritma pengurutan seleksi maksimum atau maximum selection sort Yaitu dengan mencari nilai terbesar dari array dan array dan digunakan sebagai pembanding. Pseudocode M in im um Selec Selection tion Sort procedure MinSelectionSort(input/output A : Larik, input n : integer) DEKLARASI : i, j : integer imin : integer temp : integer ALGORITMA : for i
1
to n-1 do imin i for j i+1 to n do if A[j] < A[imin] then imin j
endif endfor temp A[i] A[i] A[imin] A[imin] temp endfor end procedure
7
Pseudocode M axim um Selection Selection Sort Sort procedure MaxSelectionSort(input/output L : Larik, input n : integer) DEKLARASI : i, j : integer imaks : integer temp : integer DEFINISI : for i
n
downto 2 do imaks 1 for j 2 to i do if L[j] > L[imaks] then imaks j endif endfor temp L[i]
L[i] L[imaks] L[imaks] temp endfor end procedure
Algoritma pengurutan seleksi ( selection sort ) adalah algoritma yang tidak stabil, karena urutan beberapa elemen yang sama berbeda antara sebelum dan sesudah pengurutan. Algoritma ini juga termasuk algoritma pengurutan internal, karena melakukan sorting di dalam array itu array itu sendiri, dan menyimpan datanya di dalam memori komputer. Yang akan dibahas kali ini adalah menggunakan pengurutan seleksi minimum (minimum selection sort ) secara menaik (ascending (ascending ), ), yaitu selection sort dengan menggunakan nilai terkecil di dalam array sebagai array sebagai pembanding. L oop oop I nvari nvari ant M in imum Selection lection Sort Sort
Statement Saat awal algoritma dijalankan, nilai imin imin berisi indeks elemen terkecil dari larik A[1...j - 1].
Initialization
Sebelum iterasi atau pass pertama dilakukan, nilai j = i + 1, imin imin berisi indeks elemen terkecil dari larik A[i...i] yang merupakan indeks elemen paling pertama larik A.
Maintenance
Sebelum iterasi ke- jth, imin imin berisi indeks elemen terkecil dari larik A[i...j - 1]. Kemudian setelah dijalankan, jika A[j] < A[imin A[imin]] maka imin bernilai imin bernilai sama dengan j dan menyimpan indeks terkecil larik A[i...j].
Termination 8
Sebelum iterasi ke- (n + 1)th, j = n + 1, imin imin berisi indeks terkecil dari elemen larik A[i...n].
Simulasi Algoritma Pengurutan Seleksi (Sel ) Sel ection Sor Sor t Contoh, kita memiliki sebuah larik (array ( array)) (A) yang memiliki 7 buah elemen. Larik
tersebut akan diurutkan secara menaik (ascending ( ascending ) dengan mencari nilai minimum sebagai pembanding. 26
19
38
3
9
13
21
1. Pass 1 Cari nilai elemen terkecil dari array array (larik) A[1...7] dengan membandingkan
antar nilai elemen array, array, didapatkan elemen terkecil A[4] = 3. Tukarkan dengan nilai elemen terujung (awal) yaitu A[1]. Lalu elemen A[1]
tersebut sudah terurut. 3
19
38
26
9
13
21
2. Pass 2 Cari nilai elemen terkecil dari array array (larik) A[2...7] dengan membandingkan
antar nilai elemen array, array, didapatkan elemen terkecil A[5] = 9. Tukarkan dengan nilai elemen terujung (awal) yaitu A[2]. Lalu elemen A[2]
tersebut sudah terurut. 3
9
38
26
19
13
21
3. Pass 3 Cari nilai elemen terkecil dari array array (larik) A[3...7] dengan membandingkan
antar nilai elemen array, array, didapatkan elemen terkecil A[6] = 13. Tukarkan dengan nilai elemen terujung (awal) yaitu A[3]. Lalu elemen A[3]
tersebut sudah terurut. 3
9
13
26
19
38
21
4. Pass 4
Cari nilai elemen terkecil dari array array (larik) A[4...7] dengan membandingkan antar nilai elemen array, array, didapatkan elemen terkecil A[5] = 19.
9
Tukarkan dengan nilai elemen terujung (awal) yaitu A[4]. Lalu elemen A[4]
tersebut sudah terurut. 3
9
13
19
26
38
21
5. Pass 5 Cari nilai elemen terkecil dari array array (larik) A[5...7] dengan membandingkan
antar nilai elemen array, array, didapatkan elemen terkecil A[7] = 21. Tukarkan dengan nilai elemen terujung (awal) yaitu A[5]. Lalu elemen A[5]
tersebut sudah terurut. 3
9
13
19
21
38
26
6. Pass 6 (n-1) Cari nilai elemen terkecil dari array array (larik) A[6...7] dengan membandingkan
antar nilai elemen array, array, didapatkan elemen terkecil A[7] = 26. Tukarkan dengan nilai elemen terujung (awal) yaitu A[6]. Lalu elemen A[6]
tersebut sudah terurut. 3
9
13
19
21
26
38
Elemen yang tersisa yaitu elemen terakhir A[7] = 38. Elemen tersebut tidak perlu diurutkan karena elemen tersebut berada pada posisi yang sudah terurut. Jadi array atau array atau larik A sudah terurut. Hasil array A array A yang sudah terurut yaitu : 3
9
13
19
21
26
38
Sel ection Sor Sor t Analisis dan Runn in g Ti me Se Running time algoritma time algoritma pengurutan seleksi ( selection ( selection sort ) dapat dihitung dengan : SELECTION SORT
for i
Cost
Times
1
to n-1 do
C1
n
imin
i
C2
n-1
for j
i+1
C3
to n do
if L[j] < L[imin]
then imin
C4
C5
j
10
( ( )
endif
0
endfor
0
temp
L[i]
C6
L[i]
L[imin]
C7
n-1
temp
C8 0
n-1 n
L[imin] endfor
n-1
Keterangan :
o
t i,j jika kondisi kondisi if benar, benar, 0 jika salah. i,j bernilai 1 jika
C3.
C4.
C5.
∑ ∑
∑
= C3.
∑
+ C3.
t ( ) = C
+ C
= C3.
3.
= C4.
5.
i,j i,j
dapat bernilai bernilai 1 atau 0.
Ketika kondisi best case maka case maka kondisi if salah, salah, t i,j i,j = 0. Kondisi best case terjadi jika data dalam elemen array sudah array sudah terurut. Maka :
Didapatkan notasi asimptotik best case selection sort adalah adalah
o
Ketika kondisi worst case maka case maka kondisi if benar, benar, t i,j i,j = 1. Kondisi worst case terjadi jika data dalam elemen array terurut array terurut secara terbalik. Maka :
Didapatkan notasi asimptotik worst case selection sort adalah adalah
o
Jadi baik dalam kondisi worst case, average case maupun maupun best case case didapatkan kompleksitas waktu algoritma selection algoritma selection sort yaitu yaitu :
11
2. M er ge Sort Sor t Penjelasan Penjelasan Singkat M er ge Sor Algoritma merge sort dirancang untuk memenuhi kebutuhan pengurutan jika data
yang diurutkan berjumlah banyak, dan tidak memungkinkan untuk ditampung dalam memori komputer. Cara kerja atau konsep dari algoritma merge sort adalah menggunakan metode rekursif dan teknik divide and conquer . Rekurensi (Reccurence ) Merupakan sebuah fungsi atau prosedur yang digambarkan secara rekursif. Rekursif
adalah proses untuk memanggil dirinya sendiri. Dan fungsi running time-nya time-nya dapat digambarkan oleh recurrence (Rekurensi). Definisi rekursif disusun oleh dua bagian, yaitu : 1. Basis, yaitu bagian yang berisi kasus yang terdefinisi secara eksplisit dan berguna untuk menghentikan rekursif (memberikan sebuah nilai yang terdefinisi pada fungsi rekursif). 2. Rekurens, yaitu bagian yang mendefinisikan objek dalam terminologi dirinya sendiri. Misalnya pada proses untuk menghitung faktorial dari n, maka :
Basis :
n!=1
,n=0
Rekurens :
n ! = n x (n - 1) !
,n>0
Di vide and Conquer Conquer
1. Divide : membagi sebuah array menjadi array menjadi dua array, array, sebuah problem dipecah menjadi sub-sub problem yang memiliki kemiripan dengan masalah semula namun berukuran lebih kecil. 2. Conquer : menyelesaikan masalah secara rekursif, yaitu mengurutkan setiap array. array. 3. Combine : menggabungkan solusi yaitu dua array yang array yang sudah terurut. Sort Pseudocode M erge Sort PROCEDURE MERGESORT(A, p, r) IF p < r // Check for base case THEN q = FLOOR (p + r)/2 MERGESORT(A, p, q) MERGESORT(A, q + 1, r) MERGE(A, p, q, r)
⌊
⌋
// Divide step. // Conquer step. // Conquer step. // Conquer step.
PROCEDURE MERGE(A, p, q, r) 12
n1 ← q − p + 1 n2 ← r − q Create arrays L[1 . . n1 + 1] and R[1 . . n2 + 1] FOR i ← 1 TO n1 DO L[i] ← A[p + i − 1] FOR j ← 1 TO n2 DO R[j] ← A[q + j] L[n1 + 1] ← ∞ R[n2 + 1] ← ∞ i ← 1 j ← 1 FOR k ← p TO r DO IF L[i] ≤ R[j] THEN A[k] ← L[i] i ← i + 1 ELSE A[k] ← R[j] j ← j + 1
L oop oop I nvari nvari ant pada Prosedur Merge
Statement Setiap iterasi pada for pada for (pengulang) (pengulang) yang terakhir, sub-array A[p...k sub-array A[p...k - 1] berisi nilai k-p elemen terkecil dari array L array L dan R dalam keadaan yang sudah terurut. L[i] dan R[j] merupakan elemen terkecil dari array L array L dan R yang tidak di-copy di- copy ke ke array A. array A.
Initialization
Sebelum iterasi pertama dilakukan, k = p. Sub-array A[p…k - 1] berisi 0 elemen terkecil dari array L array L dan R. Ketika i = j = 1, L[i] dan R[j] adalah elemen terkecil dari array array yang tidak di-copy di- copy ke array array A. Kedua array L dan R dalam keadaan yang terurut.
Maintenance Misalkan L[i] ≤ R[j], maka L[i] adalah elemen terkecil yang tidak di-copy di-copy ke array th
A. A[p…k - 1] adalah k - p elemen terkecil, L[i] adalah (k – (k – p p + 1) elemen terkecil. Kemudian L[i] di-copy ke A[k], A[p…k] berisi k – p + 1 elemen terkecil. Secara berulang, nilai k + i membuat perulangan (loop invariant ). ). Jika L[i] > R[j], maka nilai R[j] di-copy di-copy ke array array A[k], dan nilai j + 1 agar pengulangan dapat terus dilakukan.
Termination Ketika nilai k = r + 1, A[p…k - 1] = A[p…r] berisi k - p elemen terkecil dalam keadaan yang terurut. Menghasilkan k - p = r + 1 - p elemen terkecil dalam keadaan yang terurut. Kedua array L array L dan R berisi n1 + n2 + 2 = r -p + 3 elemen, dan dua buah ∞ telah di-copy kembali ke array A. array A.
13
Simulasi Algoritma M erge Sort Sort Contoh, kita memiliki sebuah larik (array ( array)) (A) yang memiliki 4 buah elemen. Larik
tersebut akan diurutkan secara menaik (ascending ( ascending ). ). Dengan nilai p adalah indeks elemen awal, yaitu p = 0. Nilai r adalah indeks elemen akhir, yaitu r = 3. 3. 12
9
24
2
A[0...3] = 1. MERGESORT(A, 0, 3) .
Kemudian diperiksa apakah jika p < r , (0 < 3), jika benar maka dihitung q =
⌊
⌋
(p + r)/2 = 1.
Kemudian dipanggil MERGESORT(A, 0, 1) , MERGESORT(A, 2, 3) dan MERGE(A, 0, 1, 3).
1.1. MERGESORT(A, 0, 1)
Kemudian diperiksa apakah jika p < r, (0 < 1), jika benar maka dihitung q =
⌊
⌋
(p + r)/2 = 0.
Kemudian dipanggil MERGESORT(A, 0, 0) , MERGESORT(A, 1, 1) dan MERGE(A, 0, 0, 1) . 12
9
A[0...1] =
1.1.1. MERGESORT(A, 0, 0) Kemudian diperiksa apakah jika p < r, (0 < 0), karena salah maka rekursif pada bagian ini selesai. 1.1.2. MERGESORT(A, 1, 1) Kemudian diperiksa apakah jika p < r, (1 < 1), karena salah maka rekursif pada bagian ini selesai. 1.1.3. MERGE(A, 0, 0, 1)
Sesuai dengan algoritma maka nilai : o
n1 = q − p + 1 = 1
o
n2 = r – q = 1.
Lalu buat dua buah array bernama array bernama L dan R dengan jumlah elemen o
L[1 . . n1 + 1] yaitu L[1...2]
o
R[1 . . n2 + 1] yaitu R[1...2]
Perulangan pada : 14
o
FOR i ← 1 TO n1 DO L[i] ← A[p + i − 1]
o
nilai L[1] = A[0] = 12. 12
o
L[1] =
Perulangan pada : o
FOR j ← 1 TO n2 DO R[j] ← A[q + j ]
o
nilai R[1] = A[1] = 9. 9
o
R[1] =
Kemudian ditambahkan L[n1 + 1] ← ∞ dan R[n2 + 1] ← ∞, sehingga L[2] = ∞ dan R[2] = ∞. Sehingga array array L dan R
berisi : 12
9
∞
Array L Array L =
∞
dan Array dan Array R R =
Kedua array tersebut array tersebut sudah dalam keadaan terurut.
Nilai i dan j di inisialisasi menjadi i = 1 dan j = 1. Kemudian lakukan pengulangan pada : o
o
FOR k ← p TO r DO IF L[i] ≤ R[j] THEN A[k] ← L[i] i ← i + 1 ELSE A[k] ← R[j] j ← j + 1 Untuk menggabungkan array array L dan R ke array array A dalam
keadaan terurut. o
Didapatkan :
L[1] L[1] ≤ R[1], R[1], 12 ≤ 9 = False, maka A[0] = R[1] = 9
L[1] L[1] ≤ R[2], 12 ≤ ∞ = True, maka maka A[1] = L[1] L[1] = 12. 12. 9
o
12
A[0...1] =
1.2. MERGESORT(A, 2, 3)
15
Kemudian diperiksa apakah jika p < r, (2 < 3), jika benar maka dihitung q =
⌊
⌋
(p + r)/2 = 2.
Kemudian dipanggil MERGESORT(A, 2, 2) , MERGESORT(A, 3, 3) dan MERGE(A, 2, 2, 3) . 24
2
A[2...3] =
1.2.1. MERGESORT(A, 2, 2) Kemudian diperiksa apakah jika p < r, (2 < 2), karena salah maka rekursif pada bagian ini selesai. 1.2.2. MERGESORT(A, 3, 3) Kemudian diperiksa apakah jika p < r, (3 < 3), karena salah maka rekursif pada bagian ini selesai. 1.2.3. MERGE(A, 2, 2, 3)
Sesuai dengan algoritma maka nilai : o
n1 = q − p + 1 = 1
o
n2 = r – q = 1.
Lalu buat dua buah array bernama array bernama L dan R dengan jumlah elemen o
L[1 . . n1 + 1] yaitu L[1...2]
o
R[1 . . n2 + 1] yaitu R[1...2]
Perulangan pada : o
FOR i ← 1 TO n1 DO L[i] ← A[p + i − 1]
o
nilai L[1] = A[2] = 24. 24
o
L[1] =
Perulangan pada : o
FOR j ← 1 TO n2 DO R[j] ← A[q + j]
o
nilai R[1] = A[3] = 2. 2
o
R[1] =
16
Kemudian ditambahkan L[n1 + 1] ← ∞ dan R[n2 + 1] ← array L dan R ∞, sehingga L[2] = ∞ dan R[2] = ∞. Sehingga array berisi : 24
2
∞
Array L Array L =
∞
dan Array dan Array R R =
Kedua array tersebut array tersebut sudah dalam keadaan terurut.
Nilai i dan j di inisialisasi menjadi i = 1 dan j = 1. Kemudian lakukan pengulangan pada : o
o
FOR k ← p TO r DO IF L[i] ≤ R[j] THEN A[k] ← L[i] i ← i + 1 ELSE A[k] ← R[j] j ← j + 1 Untuk menggabungkan array array L dan R ke array array A dalam
keadaan terurut. o
Didapatkan :
L[1] L[1] ≤ R[1], R[1], 24 ≤ 2 = False, maka A[2] = R[1] = 2
L[1] L[1] ≤ R[2], R[2], 24 ≤ ∞ = True, maka A[3] = L[1] = 24. 2
o
24
A[2...3] =
1.3. MERGE(A, 0, 1, 3)
Sesuai dengan algoritma maka nilai : o
n1 = q − p + 1 = 2
o
n2 = r – q = 2.
Lalu buat dua buah array bernama array bernama L dan R dengan jumlah elemen o
L[1 . . n1 + 1] yaitu L[1...3]
o
R[1 . . n2 + 1] yaitu R[1...3]
Perulangan pada : o
FOR i ← 1 TO n1 DO L[i] ← A[p + i − 1]
o
nilai L[1] = A[0] = 9 dan L[2] = A[1] = 12. 9
o
12
L[1...2] =
17
Perulangan pada : o
FOR j ← 1 TO n2 DO R[j] ← A[q + j]
o
nilai R[1] = A[2] = 2 dan R[2] = A[3] = 24. 2
o
24
R[1...2] =
Kemudian ditambahkan L[n1 + 1] ← ∞ dan R[n2 + 1] ← ∞ , sehingga L[2] = ∞ dan ∞ dan R [2] [2] = ∞. ∞. Sehingga array L array L dan R berisi : 9
12
2
∞
Array L Array L =
24
∞
dan Array dan Array R R =
Kedua array tersebut array tersebut sudah dalam keadaan terurut.
Nilai i dan j di inisialisasi menjadi i = 1 dan j = 1. Kemudian lakukan pengulangan pada pada : o
o
FOR k ← p TO r DO IF L[i] ≤ R[j] THEN A[k] ← L[i] i ← i + 1 ELSE A[k] ← R[j] j ← j + 1 Untuk menggabungkan array array L dan R ke array array A dalam keadaan
terurut. o
Didapatkan :
L[1] L[1] ≤ R[1], R[1], 9 ≤ 2 = False, False, maka A[0] A[0] = R[1] = 2
L[1] L[1] ≤ R[2], R[2], 9 ≤ 24 = True, True, maka A[1] = L[1] = 9.
L[2] L[2] ≤ R[2], R[2], 12 ≤ 24 = True, maka maka A[2] = L[2] = 12
L[3] L[3] ≤ R[2], R[2], ∞ ≤ 24 = False, maka A[3] = R[2] = 24. 2
o
9
12
24
A[0...3] =
Jika digambarkan secara sederhana maka proses eksekusi algoritma merge sort adalah :
18
Array unsorted
12
A[0...3]
9
24
2
divide to sub-array
12
A[0...1]
24
9
L[]
merge & sort sub-array L & R to array A
9
A[0...1]
A[2...3]
divide to sub-array L & R
divide to sub-array L & R
12
2
9
24
R[]
L[]
12
2 R[]
merge & sort sub-array L & R to array A
2
24
A[2...3]
merge & sort subarray to array A Sorted Array
A[0...3]
2
9
12
24
Hasil pengurutannya adalah array A array A dengan elemen seperti sepert i dibawah.
2
9
12
24
A[0...3] = Analisis dan Runn in g Time Merge Sort
Merge sort selalu membagi setiap array array menjadi dua sub-array sub-array hingga mencapai basis, sehingga kompleksitas dari algoritma merge sort, berlaku untuk semua kasus (Worst Case = Best Case = Average Case). Case ).
Untuk memudahkan, kita anggap jumlah elemen array array (n) adalah kelipatan 2, jadi setiap dilakukan divide (pemecahan divide (pemecahan menjadi dua sub-array), sub-array), kedua sub-array sub-array akan berukuran n/2.
Basis : untuk n = 1, maka array tersebut array tersebut sudah terurut dengan sendirinya.
Rekurens : untuk n > 1, maka akan dilakukan langkah-langkah merge sort , yaitu : Divide : Hitung nilai q yang merupakan rata-rata rata- rata dari p + r, yang bernilai Θ(1). o Divide : o
Conquer : Secara rekursif menyelesaikan 2 sub-array, sub-array, setiap sub-array berukuran n/2, maka maka bernilai 2T(n/2). 19
o
Combine Combine : Menggabungkan element dari sub-array sub-array ke dalam array dengan prosedur MERGE, bernilai Θ(n).
Jumlahkan semua fungsi yang dihasilkan, sehingga dihasilkan rekurens :
{ }
Dari rekurens tersebut di ubah untuk mendapatkan kompleksitas waktu algoritma
merge sort, sehingga
Catatan : log n = log2 n = 2log n.
Kompleksitas waktu tersebut dapatk dijelaskan dari recursif tree berikut tree berikut : cn), yang memiliki dua sub-array dua sub-array,, masing-masing bernilai T(n/2). o Array awal (cn),
o
Kemudian sub-array sub-array tersebut di bagi lagi menjadi dua sub-sub-array, sub-sub-array, jadi bernilai T(n/4) dan seterusya.
o
Di dapatkan tinggi pohon rekursif adalah log n, dan memiliki sebanyak log n + 1 level. Setiap level bernilai cn, cn, sehingga cn log cn log n + cn. cn.
o
Koefisien c tidak perlu di masukkan, sehingga kompleksitas waktunya menjadi
3. Analisis Perbandingan Sel dengan dengan M er ge Sort Sel ection cti on Sort or t Dari hasil analisis sebelumnya telah didapatkan kompleksitas waktu algoritma pengurutan seleksi ( selection selection sort ) dan merge sort , yaitu : 1. Selection sort memiliki kompleksitas waktu untuk kondisi best case, average case maupun worst case dengan case dengan :
20
2. Merge sort memiliki kompleksitas waktu untuk kondisi best case, average case maupun worst case dengan case dengan :
Jika dibandingkan dari kompleksitas waktu kedua algoritma tersebut maka algoritma yang running time-nya time-nya lebih cepat adalah algoritma merge sort . Baik dalam keadaan best case, average case case maupun worst case. Merge sort memiliki running time time yang lebih cepat dibandingkan dibandingkan selection selection sort , karena nilai n log n lebih n lebih kecil dari n2. Untuk jumlah data atau elemen array yang array yang sedikit, perbedaan running time selection sort dan dan merge sort tidak tidak terlalu terlihat, bisa saja lebih cepat selection cepat selection sort atau atau merge sort . Hal ini dapat dipengaruhi oleh kemampuan komputer, jumlah memori dan faktor lain. Namun jika jumlah data atau elemen array yang array yang sangat banyak, perbedaan running time selection sort dan dan merge sort akan akan sangat terlihat, semakin banyak data yang akan diurutkan, semakin terlihat perbedaan running time-nya. time-nya.
21
BAB IV KESIMPULAN & SARAN
1. Kesimpulan Hasil analisis perbandingan selection sort dan merge sort menunjukkan bahwa running time merge sort lebih cepat. Hal ini akan terlihat jika jumlah data yang akan diurutkan berjumlah banyak, semakin banyak data semakin terlihat perbedaan kecepatan algoritma. Sedangkan jika data berjumlah sedikit maka perbedaan antara selection sort dan merge sort tidak tidak begitu siginifikan. Perlu dipertimbangkan juga faktor lain yang mempengaruhi kecepatan eksekusi sebuah algoritma selain kompleksitas waktu dan jumlah data, yaitu faktor kemampuan komputer, jumlah memori dan lain-lain. Selain itu pertimbangan dari penggunaan sebuah algoritma tidak hanya di lihat dari running time-nya, time-nya, tetapi dari kebutuhan. Misalnya kita membutuhkan algoritma untuk mengurutkan jumlah data yang sedikit (kurang dari 100 elemen), maka kita dapat menggunakan selection sort daripada merge sort karena perbedaan kecepatan yang tidak signifikan.
2. Saran Penulis menyarankan untuk penulisan karya tulis selanjutnya agar algoritma pengurutan yang dibahas lebih banyak lagi disertai dengan simulasi dan analisis, serta diberikan contoh program atau program simulasi step-by-step untuk memperjelas materi pembahasan.
22
DAFTAR PUSTAKA
Fanani, Ikhsan. Penggunaan Ikhsan. Penggunaan ”Big O Notation” untuk Menganalisa Efisiensi Algoritma . Program Studi Teknik Informatika, Institut Teknologi Bandung. M. Fachrurrozi, Dwi Rosa Indah. 2006. Modul Praktikum “Algoritma “Algoritma dan Pemrograman I”. I”. Laboratorium Dasar Komputer Program Ilmu Komputer Universitas Sriwijaya. Ria Hari Gusmita, ST., M.Kom. Algoritma dan Pemrograman 2 : Pengurutan (Bubble dan Selection Sort). Sort) . Internet :
http://andikafisma.wordpress.com/algoritma-divide-and-conquer/,, diakses pada 29 Mei http://andikafisma.wordpress.com/algoritma-divide-and-conquer/ 2012, 22:15. http://blog.ub.ac.id/satriabram/2012/03/13/rangkuman-mengenai-asymptotic-notation jenis-notationnya-beserta-contoh-algoritma-dan-perhitungan-notationnya/,, diakses pada 31 jenis-notationnya-beserta-contoh-algoritma-dan-perhitungan-notationnya/ Mei 2012, 21:58. http://informatikauad.files.wordpress.com/2010/03/catatan-analisis-algoritma.doc,, http://informatikauad.files.wordpress.com/2010/03/catatan-analisis-algoritma.doc diakses pada 31 Mei 2012, 21:53. http://personal.denison.edu/~kretchmar/272/SelectionSortAnalysis.pdf , diakses pada 31 Mei 2012, 23:44. http://www.cse.iitk.ac.in/users/dsrkg/cs210/applets/sortingII/mergeSort/mergeSort.html , diakses pada 31 Mei 2012, 15:35. http://www.iti.fh-flensburg.de/lang/algorithmen/sortieren/merge/mergen.htm,, http://www.iti.fh-flensburg.de/lang/algorithmen/sortieren/merge/mergen.htm
diakses
pada 30 Mei 2012, 23:08. http://www.personal.kent.edu/~rmuhamma/Algorithms/MyAlgorithms/Sorting/mergeS ort.htm,, diakses pada 30 Mei 2012, 23:10. ort.htm http://www.scribd.com/doc/51164311/pengurutan,, diakses pada 30 Mei 2012, 22:08. http://www.scribd.com/doc/51164311/pengurutan http://www.shannarasite.org/kb/kbse30.html,, diakses pada 31 Mei 2012, 09:35. http://www.shannarasite.org/kb/kbse30.html 23
http://www.rodensi.blog.usu.ac.id/2010/11/28/merge-sort-dengan-java/,, diakses pada http://www.rodensi.blog.usu.ac.id/2010/11/28/merge-sort-dengan-java/ 31 Mei 2012, 22:30.
24