DAA - 0-1 Sırt Çantası

Bu eğitimde, daha önce Açgözlü yaklaşımı kullanarak Kesirli Sırt Çantası problemini tartışmıştık. Greedy yaklaşımının Kesirli Sırt Çantası için en uygun çözümü sunduğunu gösterdik. Bununla birlikte, bu bölüm 0-1 Sırt Çantası problemini ve analizini kapsayacaktır.

0-1 Sırt Çantasında, eşyalar kırılamaz, yani hırsız eşyayı bir bütün olarak almalı ya da bırakmalıdır. 0-1 Sırt Çantası olarak adlandırılmasının nedeni budur.

Dolayısıyla, 0-1 Sırt Çantası durumunda, değeri xi herhangi biri olabilir 0 veya 1, diğer kısıtlamaların aynı kaldığı durumlarda.

0-1 Sırt Çantası Açgözlü yaklaşımla çözülemez. Açgözlü yaklaşım, optimal bir çözüm sağlamaz. Çoğu durumda, Açgözlü yaklaşım en uygun çözümü verebilir.

Aşağıdaki örnekler ifademizi oluşturacaktır.

Örnek 1

Sırt çantasının kapasitesinin W = 25 olduğunu ve eşyaların aşağıdaki tabloda gösterildiği gibi olduğunu düşünelim.

Öğe Bir B C D
Kar 24 18 18 10
Ağırlık 24 10 10 7

Birim ağırlık başına kar dikkate alınmadan (pi/wi), bu sorunu çözmek için Açgözlü yaklaşımı uygularsak, ilk madde Ao maksimum katkıda bulunacak şekilde seçilecektir i tüm unsurları arasında anne karı.

Öğeyi seçtikten sonra A, başka öğe seçilmeyecek. Bu nedenle, bu belirli ürün grubu için toplam kâr24. Oysa en uygun çözüme, öğeler seçilerek ulaşılabilir,B ve toplam kârın 18 + 18 = 36 olduğu C.

Örnek-2

Maddeleri genel faydaya göre seçmek yerine, bu örnekte maddeler p i / w i oranına göre seçilmiştir . Sırt çantasının kapasitesinin W = 60 olduğunu ve eşyaların aşağıdaki tabloda gösterildiği gibi olduğunu düşünelim .

Öğe Bir B C
Fiyat 100 280 120
Ağırlık 10 40 20
Oran 10 7 6

Açgözlü yaklaşımı kullanarak, ilk madde Aseçildi. Sonra bir sonraki öğeBseçilmiş. Dolayısıyla, toplam kâr100 + 280 = 380. Bununla birlikte, bu örneğin en uygun çözümü, öğeleri seçerek elde edilebilir,B ve C, toplam kâr nerede 280 + 120 = 400.

Dolayısıyla, Açgözlü yaklaşımın optimal bir çözüm vermeyebileceği sonucuna varılabilir.

0-1 Sırt Çantasını çözmek için Dinamik Programlama yaklaşımı gereklidir.

Sorun bildirimi

Bir hırsız bir mağaza soyarak ve maksimum taşıyabilen i arasında mal ağırlığıWsırt çantasına. Varn öğeleri ve ağırlığı ith öğe wi ve bu öğeyi seçmenin karı pi. Hırsız hangi eşyaları almalı?

Dinamik Programlama Yaklaşımı

İzin Vermek i en uygun çözümde en yüksek numaralı öğe olmak S için Wdolar. SonraS' = S - {i} için en uygun çözümdür W - wi dolar ve çözümün değeri S dır-dir Vi artı alt problemin değeri.

Bu gerçeği aşağıdaki formülle ifade edebiliriz: c[i, w] öğeler için çözüm olmak 1,2, … , ive maksimum i mum ağırlıkw.

Algoritma aşağıdaki girdileri alır

  • Maksimum i mum ağırlıkW

  • Öğe sayısı n

  • İki dizi v = <v1, v2, …, vn> ve w = <w1, w2, …, wn>

Dynamic-0-1-knapsack (v, w, n, W) 
for w = 0 to W do 
   c[0, w] = 0 
for i = 1 to n do 
   c[i, 0] = 0 
   for w = 1 to W do 
      if wi ≤ w then 
         if vi + c[i-1, w-wi] then 
            c[i, w] = vi + c[i-1, w-wi] 
         else c[i, w] = c[i-1, w] 
      else 
         c[i, w] = c[i-1, w]

Alınacak öğe seti, tablodan başlayarak çıkarılabilir. c[n, w] ve optimal değerlerin geldiği yeri geriye doğru izlemek.

Eğer c [i, W] = C [i-1, a] , daha sonra ürüni çözümün bir parçası değil ve izlemeye devam ediyoruz c[i-1, w]. Aksi takdirde öğei çözümün bir parçası ve izlemeye devam ediyoruz c[i-1, w-W].

Analiz

Bu algoritma, c tablosunda ( n + 1). ( W + 1) girişleri olduğu için entry ( n , w ) kez alır , burada her girişin hesaplanması θ (1) süre gerektirir.