DAA - Masalah Penjual Perjalanan
Pernyataan masalah
Seorang pelancong perlu mengunjungi semua kota dari daftar, di mana jarak antara semua kota diketahui dan setiap kota harus dikunjungi hanya sekali. Apa rute terpendek yang dia kunjungi setiap kota tepat satu kali dan kembali ke kota asal?
Larutan
Masalah penjual keliling adalah masalah komputasi yang paling terkenal. Kita dapat menggunakan pendekatan brute-force untuk mengevaluasi setiap kemungkinan tur dan memilih yang terbaik. Untukn jumlah simpul dalam grafik, ada (n - 1)! sejumlah kemungkinan.
Alih-alih brute-force menggunakan pendekatan pemrograman dinamis, solusi dapat diperoleh dalam waktu yang lebih singkat, meskipun tidak ada algoritma waktu polinomial.
Mari kita perhatikan grafik G = (V, E), dimana V adalah sekumpulan kota dan Eadalah satu set tepi berbobot. Sebuah pinggire(u, v) mewakili simpul itu u dan vterhubung. Jarak antar titiku dan v adalah d(u, v), yang seharusnya tidak negatif.
Misalkan kita sudah mulai di kota 1 dan setelah mengunjungi beberapa kota sekarang kita berada di kota j. Karenanya, ini adalah tur parsial. Kami tentu perlu tahuj, karena ini akan menentukan kota mana yang paling nyaman untuk dikunjungi selanjutnya. Kita juga perlu mengetahui semua kota yang dikunjungi selama ini, agar tidak terulang lagi. Oleh karena itu, ini adalah sub-masalah yang sesuai.
Untuk subset kota S Є {1, 2, 3, ... , n} itu termasuk 1, dan j Є S, biarkan C(S, j) menjadi panjang jalur terpendek yang mengunjungi setiap node S tepat sekali, mulai dari 1 dan berakhir pada j.
Kapan |S| > 1, kami definisikanC(S, 1) = ∝ karena jalur tidak bisa dimulai dan diakhiri 1.
Sekarang, ungkapkan C(S, j)dalam hal sub-masalah yang lebih kecil. Kita harus mulai1 dan diakhiri pada j. Kita harus memilih kota berikutnya sedemikian rupa
$$ C (S, j) = min \: C (S - \ lbrace j \ rbrace, i) + d (i, j) \: where \: i \ in S \: dan \: i \ neq jc ( S, j) = minC (s- \ lbrace j \ rbrace, i) + d (i, j) \: where \: i \ in S \: dan \: i \ neq j $$
Algorithm: Traveling-Salesman-Problem
C ({1}, 1) = 0
for s = 2 to n do
for all subsets S Є {1, 2, 3, … , n} of size s and containing 1
C (S, 1) = ∞
for all j Є S and j ≠ 1
C (S, j) = min {C (S – {j}, i) + d(i, j) for i Є S and i ≠ j}
Return minj C ({1, 2, 3, …, n}, j) + d(j, i)
Analisis
Ada paling banyak $ 2 ^ nn $ sub-masalah dan masing-masing membutuhkan waktu linier untuk menyelesaikannya. Oleh karena itu, total waktu berjalan adalah $ O (2 ^ nn ^ 2) $.
Contoh
Dalam contoh berikut, kami akan mengilustrasikan langkah-langkah untuk menyelesaikan masalah penjual keliling.
Dari grafik di atas, disiapkan tabel berikut.
1 | 2 | 3 | 4 | |
1 | 0 | 10 | 15 | 20 |
2 | 5 | 0 | 9 | 10 |
3 | 6 | 13 | 0 | 12 |
4 | 8 | 8 | 9 | 0 |
S = Φ
$$ \ kecil Biaya (2, \ Phi, 1) = d (2,1) = 5 \ kecil Biaya (2, \ Phi, 1) = d (2,1) = 5 $$
$$ \ kecil Biaya (3, \ Phi, 1) = d (3,1) = 6 \ kecil Biaya (3, \ Phi, 1) = d (3,1) = 6 $$
$$ \ kecil Biaya (4, \ Phi, 1) = d (4,1) = 8 \ kecil Biaya (4, \ Phi, 1) = d (4,1) = 8 $$
S = 1
$$ \ kecil Biaya (i, s) = min \ lbrace Biaya (j, s - (j)) + d [i, j] \ rbrace \ small Biaya (i, s) = min \ lbrace Biaya (j, s ) - (j)) + d [i, j] \ rbrace $$
$$ \ kecil Biaya (2, \ lbrace 3 \ rbrace, 1) = d [2,3] + Biaya (3, \ Phi, 1) = 9 + 6 = 15 biaya (2, \ lbrace3 \ rbrace, 1) = d [2,3] + biaya (3, \ Phi, 1) = 9 + 6 = 15 $$
$$ \ kecil Biaya (2, \ lbrace 4 \ rbrace, 1) = d [2,4] + Biaya (4, \ Phi, 1) = 10 + 8 = 18 biaya (2, \ lbrace4 \ rbrace, 1) = d [2,4] + biaya (4, \ Phi, 1) = 10 + 8 = 18 $$
$$ \ kecil Biaya (3, \ lbrace 2 \ rbrace, 1) = d [3,2] + Biaya (2, \ Phi, 1) = 13 + 5 = 18 biaya (3, \ lbrace2 \ rbrace, 1) = d [3,2] + biaya (2, \ Phi, 1) = 13 + 5 = 18 $$
$$ \ kecil Biaya (3, \ lbrace 4 \ rbrace, 1) = d [3,4] + Biaya (4, \ Phi, 1) = 12 + 8 = 20 biaya (3, \ lbrace4 \ rbrace, 1) = d [3,4] + biaya (4, \ Phi, 1) = 12 + 8 = 20 $$
$$ \ kecil Biaya (4, \ lbrace 3 \ rbrace, 1) = d [4,3] + Biaya (3, \ Phi, 1) = 9 + 6 = 15 biaya (4, \ lbrace3 \ rbrace, 1) = d [4,3] + biaya (3, \ Phi, 1) = 9 + 6 = 15 $$
$$ \ kecil Biaya (4, \ lbrace 2 \ rbrace, 1) = d [4,2] + Biaya (2, \ Phi, 1) = 8 + 5 = 13 biaya (4, \ lbrace2 \ rbrace, 1) = d [4,2] + biaya (2, \ Phi, 1) = 8 + 5 = 13 $$
S = 2
$$ \ small Cost (2, \ lbrace 3, 4 \ rbrace, 1) = \ begin {cases} d [2, 3] + Cost (3, \ lbrace 4 \ rbrace, 1) = 9 + 20 = 29 \ \ d [2, 4] + Biaya (4, \ lbrace 3 \ rbrace, 1) = 10 + 15 = 25 = 25 \ small Biaya (2, \ lbrace 3,4 \ rbrace, 1) \\\ lbrace d [ 2,3] + \ biaya kecil (3, \ lbrace4 \ rbrace, 1) = 9 + 20 = 29d [2,4] + \ biaya kecil (4, \ lbrace 3 \ rbrace, 1) = 10 + 15 = 25 \ end {kasus} = 25 $$
$$ \ small Cost (3, \ lbrace 2, 4 \ rbrace, 1) = \ begin {cases} d [3, 2] + Cost (2, \ lbrace 4 \ rbrace, 1) = 13 + 18 = 31 \ \ d [3, 4] + Biaya (4, \ lbrace 2 \ rbrace, 1) = 12 + 13 = 25 = 25 \ small Cost (3, \ lbrace 2,4 \ rbrace, 1) \\\ lbrace d [ 3,2] + \ biaya kecil (2, \ lbrace4 \ rbrace, 1) = 13 + 18 = 31d [3,4] + \ biaya kecil (4, \ lbrace 2 \ rbrace, 1) = 12 + 13 = 25 \ end {kasus} = 25 $$
$$ \ small Cost (4, \ lbrace 2, 3 \ rbrace, 1) = \ begin {cases} d [4, 2] + Cost (2, \ lbrace 3 \ rbrace, 1) = 8 + 15 = 23 \ \ d [4, 3] + Biaya (3, \ lbrace 2 \ rbrace, 1) = 9 + 18 = 27 = 23 \ small Biaya (4, \ lbrace 2,3 \ rbrace, 1) \\\ lbrace d [ 4,2] + \ biaya kecil (2, \ lbrace3 \ rbrace, 1) = 8 + 15 = 23d [4,3] + \ biaya kecil (3, \ lbrace 2 \ rbrace, 1) = 9 + 18 = 27 \ end {kasus} = 23 $$
S = 3
$$ \ kecil Biaya (1, \ lbrace 2, 3, 4 \ rbrace, 1) = \ begin {cases} d [1, 2] + Cost (2, \ lbrace 3, 4 \ rbrace, 1) = 10 + 25 = 35 \\ d [1, 3] + Biaya (3, \ lbrace 2, 4 \ rbrace, 1) = 15 + 25 = 40 \\ d [1, 4] + Biaya (4, \ lbrace 2, 3 \ rbrace, 1) = 20 + 23 = 43 = 35 biaya (1, \ lbrace 2,3,4 \ rbrace), 1) \\ d [1,2] + biaya (2, \ lbrace 3,4 \ rbrace , 1) = 10 + 25 = 35 \\ d [1,3] + biaya (3, \ lbrace 2,4 \ rbrace, 1) = 15 + 25 = 40 \\ d [1,4] + biaya (4 , \ lbrace 2,3 \ rbrace, 1) = 20 + 23 = 43 = 35 \ end {kasus} $$
Jalur biaya minimum adalah 35.
Mulai dari biaya {1, {2, 3, 4}, 1}, kami mendapatkan nilai minimum untuk d [1, 2]. Kapans = 3, pilih jalur dari 1 ke 2 (biayanya 10) lalu mundur. Kapans = 2, kami mendapatkan nilai minimum untuk d [4, 2]. Pilih jalur dari 2 hingga 4 (biaya 10) lalu mundur.
Kapan s = 1, kami mendapatkan nilai minimum untuk d [4, 3]. Memilih jalur 4 ke 3 (biaya 9), lalu kita akan pergi ke lalu pergi kes = Φlangkah. Kami mendapatkan nilai minimum untukd [3, 1] (biayanya 6).