Divide and Conquer
8:34 PM Audya Elita Putri 51414801 1IA24
Algoritma Divide and
Conquer adalah strategi pemecahan masalah yang besar dengan cara melakukan
pembagian masalah yang besar tersebut menjadi beberapa bagian yang lebih kecil
secara rekursif hingga masalah tersebut dapat dipecahkan secara langsung.
Solusi yang didapat dari setiap bagian kemudian digabungkan untuk membentuk
sebuah solusi yang utuh.
Contoh kasus dan pemyelesaian
>> Persoalan Minimum dan Maksimum (MinMaks)
Persoalan : Misalnya diketahui table A yang
berukuran n eleman sudah berisi nilai integer. Kita ingin menentukan nilai
minimum dan nilai maksimum sekaligus di dalam table tersebut. Misalkan tabel A
berisi elemen-elemen sebagai berikut :
Ide dasar algoritma secara Divide and Conquer :
Ukuran table hasil pembagian dapat
dibuat cukup kecil sehingga mencari minimum dan maksimum dapat diselesaikan
(SOLVE) secara lebih mudah. Dalam hal ini, ukuran kecil yang dipilih adalah 1
elemen atau 2 elemen.
Algoritma MinMaks :
1. Untuk kasus n = 1 atau n = 2,
SOLVE : Jika n = 1, maka min = maks = An.
Jika n = 2, maka bandingkan kedua elemen untuk menentukan min dan maks.
2. Untuk kasus n > 2,
DIVIDE : Bagi dua table A secara rekursif
menjadi dua bagian yang berukuran sama, yaitu bagian kiri dan bagian kanan.
CONQUER : Terapkan algoritma Divide and
Conquer untuk masing-masing bagian, dalam hal ini min dan maks dari table
bagian kiri dinyatakan dalam peubah min1 dan maks1, dan min dan maks dari table
bagian kanan dinyatakan dalam peubah min2 dan maks2.
COMBINE : Bandingkan min1 dan min2 untuk menentukan
min table A, serta bandingkan maks1 dan maks2 untuk menentukan maks table A.
sumber: http://wawanhermawan74.blogspot.com/2012/10/contoh-kasus-algoritma-divide-and.html
0 comments