Penerapan BFS dan DFS pada Pencarian Solusi Bahan Kuliah IF2151 Strategi Algoritmik Oleh: Rinaldi Munir
1
Pengorganisasian Solusi • Kemungkinan2 solusi dari persoalan membentuk ruang solusi (solution space) • Ruang solusi diorganisasikan ke dalam struktur pohon • Pencarian solusi dilakukan dengan mengunjungi (traversal) simpul-simpul di dalam pohon
2
• Pohon yang ditelusuri: pohon dinamis • Pohon dinamis: pohon yang dibangun selama pencarian solusi berlangsung • Pohon dinamis dibangun dengan 2 metode traversal: BFS dan DFS • Pohon dinamis menyatakan status-status persoalan pada saat pencarian solusi berlangsung. 3
Terminologi – Status persoalan (problem state): simpul-simpul di dalam pohon dinamis yang memenuhi kendala (constraints). – Status solusi (solution state): satu atau lebih status yang menyatakan solusi persoalan. – Status tujuan (goal state): status solusi yang merupakan simpul daun – Ruang solusi (solution space): himpunan semua status solusi. – Ruang status (state space): Seluruh simpul di dalam pohon dinamis dan pohonnya dinamakan juga pohon4 ruang status (state space tree).
Contoh 6.1. Pohon ruang status yang dibangkitkan untuk menghasilkan semua permutasi A, B, C: ()
A
B
AB
AC
ABC
ACB
BA
BAC
C
BC
CA
CB
BCA
CAB
CBA
Ket: () = status kosong • Setiap simpul di dalam pohon menyatakan status persoalan. • Status awal adalah akar yang berupa sebuah “kosong”. • Setiap daun pada pohon tersebut (ABC, ACB, BAC, BCA, CAB. Dan CBA) menyatakan status solusi, dan semua daun adalah ruang solusi.
5
Contoh 6.2. Permainan 8-puzzle: 2
1
4 7
5
6
1
8
8
3
7
(a) Susunan awal (initial state)
2
3 4
6
5
(b) Susunan akhir (goal state)
6
2
1
4
6 8
7
5
3
up
right down
2
6
2
1
6
5
8
4
1
8
4
7
5
3
7
right
left
2
6
2
6
4
1
8
4
6 1
8
7
5
3
7
5
3
left
2
3
7
left
right
1
6
2
1
4
8
4
8
5
3
7
5
up
down
2
1
6
2
1
6
2
1
6
4
5
8
4
5
8
7
4
8
7
3
7
5
5
3
6
3
up
1
6
2
1
2
4
8
4
8
7
5
3
7
5
down
2
1
6
6
4
8
3
3
7
5
down
4
7
2
6
6 1
8
5
3
... dan seterusnya
7
Metode Pencarian Melebar (BFS) 0
0
1
0
2
1
3
(i)
(ii)
0
2
4
(iii)
1
3
2
4
5
6
(iv)
Gambar 6.4. Tahapan pembentukan pohon BFS 8
S1:
S4:
AB
S10:
ABC
A
S5:
AC
S11:
ACB
S0:
()
S2:
B
S3:
S6:
S7:
S12:
S13:
BA
BAC
S8:
BC
CA
S14:
BCA CAB
C
S9:
CB
S15:
CBA
Gambar 6.5 Pembentukan pohon ruang status persoalan pembangkitan permutasi A, B, C dengan metode BFS 9
2
S0:
1
4
6 8
7
5
3
up
right down
S1:
2
6
S2:
1
6
5
8
4
1
8
4
7
5
3
7
right
left S5:
2
S6:
6
2
6
4
1
8
4
6 1
8
7
5
3
7
5
3
2
S3:
3
7
left
right
S7:
2
left
1
6
2
1
4
8
4
8
5
3
7
5
up
down
S8:
S4:
S9:
1
6
2
1
6
2
1
6
4
5
8
4
5
8
7
4
8
7
3
7
5
5
3
3
up
S10:
2
6
down
S11:
S12:
1
6
2
1
2
4
8
4
8
7
5
3
7
5
2
1
6
6
4
8
3
3
7
5
down S15:
4
7
2
6
6 1
8
5
3
... dan seterusnya
Gambar 6.6 Pembentukan pohon ruang status persoalan 8-puzzle dengan metode BFS.
10
Contoh 6.3. Sebuah mainan yang terdiri atas 3 buah blok (dinomori 1, 2, dan 3). 1 1 2
2 3
(a) Susunan awal
3
(b) Susunan akhir
• Operator perpindahan: “PINDAHKAN X ke Y”, yang berarti memindahkan objek X ke atas objek yang lain. • Pada setiap saat, hanya satu buah blok yang boleh dipindahkan. • Operator tidak digunakan untuk membangkitkan status yang sama lebih dari satu kali.
11
Pohon ruang status yang dibentuk selama pencarian solusi dengan metode BFS: S0:
1 2
3 S3: 3 S2:
S1: 1
2
3
2
1
1
3
2
S8: S4:
2 1
S9:
S6:
S5: 3
3
2
1
S10:
3
3 1
2
S7:
2 3 1
1 2
3
1
2
2
1
3
12
• Dengan mengikuti lintasan dari simput akar (S0) ke simpul solusi(S10), kita memperoleh konfigurasi urutan perpindahan blok dari status awal sampai ke status akhir. • Dengan metode BFS, jika terdapat sebuah solusi, maka BFS menjamin dapat menemukannya. • Jika terdapat lebih dari satu buah solusi, BFS selalu menemukan solusi pertama pada aras pohon yang paling rendah.
13
Kompleksitas waktu algoritma BFS: • Asumsi: setiap simpul dapat membangkitkan b buah simpul baru. • Misalkan solusi ditemukan pada aras ke-d • Jumlah maksimum seluruh simpul: 1 + b + b2 + b3 + ... + bd = (bd+1 – 1)/(b – 1) • T(n) = O(bd). • Kompleksitas ruang algoritma BFS = sama dengan kompleksitas waktunya, karena semua simpul daun dari pohon harus disimpan di dalam memori selama proses pencarian. 14
Metode Pencarian Mendalam (DFS) 0
0
0
1
1
2
(i)
(ii)
0
1
2
(iii)
0
1
3
(iv)
2
0
4
3
(v)
0
1
2
4
3
(vi)
5
1
2
4
3
5
6
(vii)
Gambar 6.9. Tahapan pembentukan pohon DFS
15
Pembentukan pohon ruang status persoalan pembangkitan permutasi A, B, C dengan metode DFS
S1:
S2:
AB
A
ABC
()
S6:
B
S7:
S4:
AC
S5:
S3:
S0:
ACB
BA
S8:
BAC
S11:
S9:
S10:
S12:
BC
CA
S13:
BCA CAB
C
S14:
CB
S15:
CBA 16
• Contoh. Sebuah bidak (pion) bergerak di dalam sebuah matriks pada Gambar 6.11. Bidak dapat memasuki elemen matriks mana saja pada baris paling atas. Dari elemen matriks yang berisi 0, bidak dapat bergerak ke bawah jika elemen matriks di bawahnya berisi 0; atau berpindah horizontal (kiri atau kanan) jika elemen di bawahnya berisi 1. Bila bidak berada pada elemen yang berisi 1, ia tidak dapat bergerak kemanapun. Tujuan permainan ini adalah mencapai elemen matriks yang mengandung 0 pada baris paling bawah. 17
1 2 3 4
1 1 0 0 1
2 0 0 1 0
3 0 1 0 0
4 0 0 0 0
Gambar 6.11 Matriks bidak Operator yang digunakan: DOWN pindahkan bidak satu posisi ke bawah LEFT pindahkan bidak satu posisi ke kiri RIGHT pindahkan bidak satu posisi ke kanan Batas kedalaman maksimum pohon ruang status diandaikan 5. 18
S0
S1 (1,1)
S4 (2,1)
S0
S2 (1,2)
S8 (1,3)
S18 (1,4)
S3 (2,2)
S9 (1,2)
S14 (1,4)
S10 (2,2)
S15 (2,4)
S7 (2,3)
S5 (3,1)
S11 (2,1)
S6 (3,2)
S12 (3,1)
S13 (2,3)
S1 (1,1)
S4 (2,1)
S2 (1,2)
S8 (1,3)
S3 (2,2)
S9 (1,4)
S7 (2,3)
S13 (1,4)
S10 (2,4)
S16 (3,4)
S5 (3,1)
S11 (3,4)
S17 (4,4)
S6 (3,2)
S12 (4,4)
Gambar 6.12
(a) Pohon ruang status yang mengandung duplikasi simpul (b) Pohon ruang status yang menghindari pembangkitan simpul yang sama. 19
• Kompleksitas waktu algoritma DFS pada kasus terburuk adalah O(bm). • Kompleksitas ruang algoritma DFS adalah O(bm), karena kita hanya hanya perlu menyimpan satu buah lintasan tunggal dari akar sampai daun, ditambah dengan simpul-simpul saudara kandungnya yang belum dikembangkan.
20
• Untuk persoalan yang memiliki banyak solusi, metode DFS lebih cepat daripada BFS, karena DFS menemukan solusi setelah mengeksplorasi hanya sebagian kecil dari seluruh ruang status. • Sedangkan BFS masih harus menelusuri semua lintasan pada aras d – 1 sebelum memeriksa solusi pada aras d.
21
Varian DFS: Metode Pencarian Mendalam Berulang (IDS = Iterative Deepening Search) • Kesulitan utama pada metode DFS adalah menentukan batas maksimum kedalaman pohon ruang status. • Strategi yang digunakan untuk memecahkan masalah kedalaman terbaik ini adalah dengan mencoba semua kedalaman yang mungkin, mula-mula kedalaman 0, kedalaman 1, kedalaman 2, dan seterusnya. 22