Warning: foreach() argument must be of type array|object, bool given in /var/www/html/web/app/themes/studypress-core-theme/template-parts/header/mobile-offcanvas.php on line 20

Suppose that we have a knapsack with total capacity of W kg. We also have n items where item j has mass\({w_j}\). The knapsack problem asks for a subset of these n items with the largest possible total mass not exceeding W.

  1. Devise a brute-force algorithm for solving the knap-sack problem.
  2. Solve the knapsack problem when the capacity of the knapsack is\(18\)kg and there are five items: a\(5 - kg\)sleeping bag, an\(8 - kg\)tent, a\(7 - kg\)food pack, a\(4 - kg\)container of water, and an\(11 - kg\)portable stove.

Short Answer

Expert verified


  1. knapsack \({\rm{(W,}}{{\rm{w}}_1},{w_2},...{w_n}:{\rm{non - negative real numbers; n: positive integer)}}\)

\(\begin{array}{l}M: = 0\\S: = \phi \end{array}\)

for all \({\rm{A}} \in {\rm{p(1,2,}}...{\rm{,n)}}\)

\({\rm{B: = 0}}\)

for all \({\rm{a}} \in {\rm{A}}\)

\({\rm{B: = B + }}{{\rm{w}}_a}\)

if \({\rm{(B > M and B}} \le {\rm{W)}}\)then

\(\begin{array}{l}M: = B\\S: = A\end{array}\)

return S

  1. Food pack and portable stove.

Step by step solution

Achieve better grades quicker with Premium

  • Unlimited AI interaction
  • Study offline
  • Say goodbye to ads
  • Export flashcards

Over 22 million students worldwide already upgrade their learning with Vaia!

01

Step 1

Given:

Total capacity knapsack: W kg

n items

item j has mass \({w_j}\)

subset of these n items with the largest possible total mass not exceeding W.

  1. We call the algorithm “knapsack”, while the input to the algorithm are the non-negative real numbers W, \({w_{1,}}{w_2},...,{w_n}\)and positive integer n.

We initially set the largest possible total mass M to \(0\), while the corresponding subset S of these n items is initially set to the empty set \(\phi \).

For all subsets of the integers from \(1\)to n, we then determine the total weight is more than the current value of the largest possible total mass M but at most W, then we update the value of M and S.

After all subsets have been processed, we return the set S (which contains the selected items that results in the largest possible total mass).

\(\begin{array}{l}M: = 0\\S: = \phi \end{array}\)

for all \({\rm{A}} \in {\rm{p(1,2,}}...{\rm{,n)}}\)

\({\rm{B: = 0}}\)

for all \({\rm{a}} \in {\rm{A}}\)

\({\rm{B: = B + }}{{\rm{w}}_a}\)

if \({\rm{(B > M and B}} \le {\rm{W)}}\)

\(\begin{array}{l}M: = B\\S: = A\\{\rm{A}} \in {\rm{p(1}}\end{array}\)

return S.

02

Step 2

  1. Given:

\({\rm{W = 18kg}}\)

Sleeping bag \({w_1} = 5kg\).

Tent: \({w_2} = 8kg\).

Food pack: \({w_3} = 7kg\).

Container of water: \({w_4} = 4kg\)

Portable stove: \({w_5} = 11kg\)

The maximal possible total mass of \(W = 18kg\)can be obtained exactly in this case by selecting the food pack of \(7kg\)and the portable stove of \(11kg\) (as \(7 + 11 = 18\)).

This the implies that a solution to the knapsack problem is the food pack and portable stove.

One App. One Place for Learning.

All the tools & learning materials you need for study success - in one app.

Get started for free

Study anywhere. Anytime. Across all devices.

Sign-up for free