• No results found

0-1-knapsack.pptx

N/A
N/A
Protected

Academic year: 2020

Share "0-1-knapsack.pptx"

Copied!
42
0
0

Loading.... (view fulltext now)

Full text

(1)

0-1 KNAPSACK PROBLEM

(2)

Knapsack problem

Given some items, pack the knapsack to get the maximum

total value. Each item has some weight and some value.

Total weight that we can carry is no more than some fixed

number W. So we must consider weights of items as well

as their values.

Item # Weight Value

1 1 8

2 3 6

3 5 5

7/25/2014

Sabah Binte Noor

(3)

Knapsack problem

There are two versions of the problem:

1.

“0-1 knapsack problem”

 Items are indivisible; you either take an item or

not.

2.

“Fractional knapsack problem”

 Items are divisible: you can take any fraction of an

item

(4)

0-1 Knapsack problem

Given a knapsack with maximum capacity

W

,

and a set

S

consisting of

n

items

Each item

i

has some weight

w

i

and benefit

value

b

i

(all

w

i

and

W

are integer values)

Problem: How to pack the knapsack to

achieve maximum total value of packed

items?

7/25/2014

Sabah Binte Noor

(5)

0-1 Knapsack problem: brute-force

approach

Let’s first solve this problem with a

straightforward algorithm

Since there are

n

items, there are

2

n

possible combinations of items.

We go through all combinations and find

the one with maximum value and with

total weight less or equal to

W

Running time will be

O(2

n

)

(6)

0-1 Knapsack problem:

dynamic programming approach

We can do better with an algorithm based on

dynamic programming

We need to carefully identify the subproblems

7/25/2014

Sabah Binte Noor

(7)

7

Defining a Subproblem

Let’s try this:

If items are labeled 1..n, then a subproblem would be to find an optimal solution for Sk = {items labeled 1, 2, .. k}

If items are labeled 1..n, then a subproblem

would be to find an optimal solution for Sk = {items labeled 1, 2, .. k}

Can we describe the final solution

(Sn ) in terms of subproblems (Sk)?

Can we describe the final solution

(Sn ) in terms of subproblems (Sk)?

Unfortunatel y, we can’t do

(8)

w

i

b

i

10 8 5

5 4

4 3

3 2

Weight Benefit

9

Item #

4 3 2 1

5

S4 S5

Defining a Subproblem

7/25/2014

Sabah Binte Noor

8

Max weight: W = 20 For S4:

Total weight: 14

Maximum benefit: 20

For S5:

Total weight: 20

Maximum benefit: 26

w1 =2 w2 =4 w3 =5 w4 =3 b1 =3 b2 =5 b3 =8 b4 =4

w1 =2 w2 =4 w3 =5 w5 =9 b1 =3 b2 =5 b3 =8 b5 =10

Solution for S4 is not part of the solution for S5!!!

(9)

Defining a Subproblem

Let’s add another parameter:

w

, which will

represent the maximum weight for each

subset of items

The subproblem then will be to compute

V[k,w], i.e.,

to find an optimal solution for S

k

= {items labeled 1, 2, .. k} in a knapsack of

size w

(10)

Recursive Formula for subproblems

The subproblem will then be to compute

V[k,w], i.e.,

to find an optimal solution for S

k

= {items labeled 1, 2, .. k} in a knapsack of

size w

Assuming knowing V[i, j], where i=0,1, 2, …

k-1, j=0,1,2, …w, how to derive V[k,w]?

7/25/2014

Sabah Binte Noor

(11)

Recursive Formula for subproblems (continued)

It means, that the best subset of

S

k

that

has total weight

w

is:

1) the best subset of Sk-1 that has total weight  w,

or

2) the best subset of Sk-1 that has total weight  w-wk

plus the item k

Recursive formula for subproblems:

(12)

Recursive Formula

 The best subset of Sk that has the total

weight  w, either contains item k or not.

 First case: wk>w. Item k can’t be part of

the solution, since if it was, the total weight would be > w, which is

unacceptable.

 Second case: wkw. Then the item k can

be in the solution, and we choose the case with greater value.

(13)

0-1 Knapsack Algorithm

13

for w = 0 to W

O(W) V[0,w] = 0

for i = 1 to n

O(N) V[i,0] = 0

for i = 1 to n Repeat n times

for w = 0 to W O(W)

if wi <= w // item i can be part of the solution

if bi + V[i-1,w-wi] > V[i-1,w] V[i,w] = bi + V[i-1,w- wi] else

V[i,w] = V[i-1,w] else

(14)

Example

Let’s run our algorithm on the following data:

 n = 4 (# of elements)

 W = 5 (max weight)

 Elements (weight, benefit):

 (2,3), (3,4), (4,5), (5,6)

7/25/2014

Sabah Binte Noor

(15)

for w = 0 to W

V[0,w] = 0

0 0 0 0 0 0

0 1 2 3

4 5

0 1 2 3

4 i\W

Example (Contd… …)

(16)

for i = 1 to n

V[i,0] = 0

0 0 0 0

0 0 0 0 0 0

0 1 2 3

4 5

0 1 2 3

4 i\W

Example (Contd… …)

7/25/2014

Sabah Binte Noor

(17)

if wi <= w // item i can be part of the solution if bi + V[i-1,w-wi] > V[i-1,w]

V[i,w] = bi + V[i-1,w- wi] else

V[i,w] = V[i-1,w]

else V[i,w] = V[i-1,w] // wi > w

0

Items: 1: (2,3) 2: (3,4) 3: (4,5) 4: (5,6)

Items: 1: (2,3) 2: (3,4) 3: (4,5) 4: (5,6)

0

i=1 bi=3 wi=2 w=1

w-wi =-1

0 0 0 0 0 0

0 1 2 3

4 5

0 1 2 3

4 i\W

0 0 0

Example (Contd… …)

(18)

Items: 1: (2,3) 2: (3,4) 3: (4,5) 4: (5,6)

Items: 1: (2,3) 2: (3,4) 3: (4,5) 4: (5,6) 3

0 0

0 0 0

0 0 0 0 0 0

0 1 2 3

4 5

0 1 2 3

4 i\W

i=1 bi=3 wi=2 w=2

w-wi =0

if wi <= w // item i can be part of the solution if bi + V[i-1,w-wi] > V[i-1,w]

V[i,w] = bi + V[i-1,w- wi] else

V[i,w] = V[i-1,w]

else V[i,w] = V[i-1,w] // wi > w

Example (Contd… …)

7/25/2014

Sabah Binte Noor

(19)

Items: 1: (2,3) 2: (3,4) 3: (4,5) 4: (5,6)

Items: 1: (2,3) 2: (3,4) 3: (4,5) 4: (5,6) 3

0 0

0 0 0

0 0 0 0 0 0

0 1 2 3

4 5

0 1 2 3

4 i\W

i=1 bi=3 wi=2 w=3

w-wi =1

if wi <= w // item i can be part of the solution if bi + V[i-1,w-wi] > V[i-1,w]

V[i,w] = bi + V[i-1,w- wi] else

V[i,w] = V[i-1,w]

else V[i,w] = V[i-1,w] // wi > w

3

Example (Contd… …)

(20)

Items: 1: (2,3) 2: (3,4) 3: (4,5) 4: (5,6)

Items: 1: (2,3) 2: (3,4) 3: (4,5) 4: (5,6) 3

0 0

0 0 0

0 0 0 0 0 0

0 1 2 3

4 5

0 1 2 3

4 i\W

i=1 bi=3 wi=2 w=4

w-wi =2

if wi <= w // item i can be part of the solution if bi + V[i-1,w-wi] > V[i-1,w]

V[i,w] = bi + V[i-1,w- wi] else

V[i,w] = V[i-1,w]

else V[i,w] = V[i-1,w] // wi > w

3 3

Example (Contd… …)

7/25/2014

Sabah Binte Noor

(21)

Items: 1: (2,3) 2: (3,4) 3: (4,5) 4: (5,6)

Items: 1: (2,3) 2: (3,4) 3: (4,5) 4: (5,6) 3

0 0

0 0 0

0 0 0 0 0 0

0 1 2 3

4 5

0 1 2 3

4 i\W

i=1 bi=3 wi=2 w=5

w-wi =3

if wi <= w // item i can be part of the solution if bi + V[i-1,w-wi] > V[i-1,w]

V[i,w] = bi + V[i-1,w- wi] else

V[i,w] = V[i-1,w]

else V[i,w] = V[i-1,w] // wi > w

3 3 3

Example (Contd… …)

(22)

Items: 1: (2,3) 2: (3,4) 3: (4,5) 4: (5,6)

Items: 1: (2,3) 2: (3,4) 3: (4,5) 4: (5,6)

0 0

0 0 0

0 0 0 0 0 0

0 1 2 3

4 5

0 1 2 3

4 i\W

i=2

bi=4 wi=3 w=1

w-wi =-2

3 3 3 3

0

if wi <= w // item i can be part of the solution if bi + V[i-1,w-wi] > V[i-1,w]

V[i,w] = bi + V[i-1,w- wi] else

V[i,w] = V[i-1,w]

else V[i,w] = V[i-1,w] // wi > w

Example (Contd… …)

7/25/2014

Sabah Binte Noor

(23)

Items: 1: (2,3) 2: (3,4) 3: (4,5) 4: (5,6)

Items: 1: (2,3) 2: (3,4) 3: (4,5) 4: (5,6)

0 0

0 0 0

0 0 0 0 0 0

0 1 2 3

4 5

0 1 2 3

4 i\W

i=2 bi=4 wi=3 w=2

w-wi =-1

3 3 3 3

3

if wi <= w // item i can be part of the solution if bi + V[i-1,w-wi] > V[i-1,w]

V[i,w] = bi + V[i-1,w- wi] else

V[i,w] = V[i-1,w]

else V[i,w] = V[i-1,w] // wi > w

0

Example (Contd… …)

(24)

Items: 1: (2,3) 2: (3,4) 3: (4,5) 4: (5,6)

Items: 1: (2,3) 2: (3,4) 3: (4,5) 4: (5,6)

0 0

0 0 0

0 0 0 0 0 0

0 1 2 3

4 5

0 1 2 3

4 i\W

i=2 bi=4 wi=3 w=3

w-wi =0

3 3 3 3

0

if wi <= w // item i can be part of the solution if bi + V[i-1,w-wi] > V[i-1,w]

V[i,w] = bi + V[i-1,w- wi] else

V[i,w] = V[i-1,w]

else V[i,w] = V[i-1,w] // wi > w 4

3

Example (Contd… …)

7/25/2014

Sabah Binte Noor

(25)

Items: 1: (2,3) 2: (3,4) 3: (4,5) 4: (5,6)

Items: 1: (2,3) 2: (3,4) 3: (4,5) 4: (5,6)

0 0

0 0 0

0 0 0 0 0 0

0 1 2 3

4 5

0 1 2 3

4 i\W

i=2 bi=4 wi=3 w=4

w-wi =1

3 3 3 3

0

if wi <= w // item i can be part of the solution if bi + V[i-1,w-wi] > V[i-1,w]

V[i,w] = bi + V[i-1,w- wi] else

V[i,w] = V[i-1,w]

else V[i,w] = V[i-1,w] // wi > w 4

3 4

Example (Contd… …)

(26)

Items: 1: (2,3) 2: (3,4) 3: (4,5) 4: (5,6)

Items: 1: (2,3) 2: (3,4) 3: (4,5) 4: (5,6)

0 0

0 0 0

0 0 0 0 0 0

0 1 2 3

4 5

0 1 2 3

4 i\W

i=2 bi=4 wi=3 w=5

w-wi =2

3 3 3 3

0

if wi <= w // item i can be part of the solution if bi + V[i-1,w-wi] > V[i-1,w]

V[i,w] = bi + V[i-1,w- wi] else

V[i,w] = V[i-1,w]

else V[i,w] = V[i-1,w] // wi > w 7

3 4 4

Example (Contd… …)

7/25/2014

Sabah Binte Noor

(27)

Items: 1: (2,3) 2: (3,4) 3: (4,5) 4: (5,6)

Items: 1: (2,3) 2: (3,4) 3: (4,5) 4: (5,6)

0 0

0 0 0

0 0 0 0 0 0

0 1 2 3

4 5

0 1 2 3

4 i\W

i=3

bi=5 wi=4 w= 1..3

3 3 3 3

0 3 4 4

if wi <= w // item i can be part of the solution if bi + V[i-1,w-wi] > V[i-1,w]

V[i,w] = bi + V[i-1,w- wi] else

V[i,w] = V[i-1,w]

else V[i,w] = V[i-1,w] // wi > w

7

3 4

0

Example (Contd… …)

(28)

Items: 1: (2,3) 2: (3,4) 3: (4,5) 4: (5,6)

Items: 1: (2,3) 2: (3,4) 3: (4,5) 4: (5,6)

0 0

0 0 0

0 0 0 0 0 0

0 1 2 3

4 5

0 1 2 3

4 i\W

i=3 bi=5 wi=4 w= 4

w- wi=0

3 3 3 3

0 3 4 4 7

0 3 4 5

if wi <= w // item i can be part of the solution if bi + V[i-1,w-wi] > V[i-1,w]

V[i,w] = bi + V[i-1,w- wi] else

V[i,w] = V[i-1,w]

else V[i,w] = V[i-1,w] // wi > w

Example (Contd… …)

7/25/2014

Sabah Binte Noor

(29)

Items: 1: (2,3) 2: (3,4) 3: (4,5) 4: (5,6)

Items: 1: (2,3) 2: (3,4) 3: (4,5) 4: (5,6)

0 0

0 0 0

0 0 0 0 0 0

0 1 2 3

4 5

0 1 2 3

4 i\W

i=3 bi=5 wi=4 w= 5

w- wi=1

3 3 3 3

0 3 4 4 7

0 3 4

if wi <= w // item i can be part of the solution if bi + V[i-1,w-wi] > V[i-1,w]

V[i,w] = bi + V[i-1,w- wi] else

V[i,w] = V[i-1,w]

else V[i,w] = V[i-1,w] // wi > w

5 7

Example (Contd… …)

(30)

Items: 1: (2,3) 2: (3,4) 3: (4,5) 4: (5,6)

Items: 1: (2,3) 2: (3,4) 3: (4,5) 4: (5,6)

0 0

0 0 0

0 0 0 0 0 0

0 1 2 3

4 5

0 1 2 3

4 i\W

i=4

bi=6 wi=5 w= 1..4

3 3 3 3

0 3 4 4

if wi <= w // item i can be part of the solution if bi + V[i-1,w-wi] > V[i-1,w]

V[i,w] = bi + V[i-1,w- wi] else

V[i,w] = V[i-1,w]

else V[i,w] = V[i-1,w] // wi > w

7

3 4

0

7

0 3 4 5

5

Example (Contd… …)

7/25/2014

Sabah Binte Noor

(31)

Items: 1: (2,3) 2: (3,4) 3: (4,5) 4: (5,6) Items: 1: (2,3) 2: (3,4) 3: (4,5) 4: (5,6) 0 0 0 0 0

0 0 0 0 0 0

0 1 2 3

4 5

0 1 2 3

4 i\W

i=4 bi=6 wi=5 w= 5

w- wi=0

3 3 3 3

0 3 4 4 7

0 3 4

if wi <= w // item i can be part of the solution if bi + V[i-1,w-wi] > V[i-1,w]

V[i,w] = bi + V[i-1,w- wi] else

V[i,w] = V[i-1,w]

else V[i,w] = V[i-1,w] // wi > w

if wi <= w // item i can be part of the solution

if bi + V[i-1,w-wi] > V[i-1,w] V[i,w] = bi + V[i-1,w- wi] else

V[i,w] = V[i-1,w]

else V[i,w] = V[i-1,w] // wi > w

5

7

7

0 3 4 5

Example (Contd… …)

(32)

Comments

This algorithm only finds the max possible

value that can be carried in the knapsack

 i.e., the value in V[n,W]

To know the items that make this maximum

value, an addition to this algorithm is

necessary

7/25/2014

Sabah Binte Noor

(33)

How to find actual Knapsack Items

All of the information we need is in the

table.

V[n

,

W

] is the maximal value of items that

can be placed in the Knapsack.

Let i=n and k=W

if

V[i,k

]

V[i

1,k

] then

mark the

i

th

item as in the knapsack

i

=

i

1

,

k

=

k-w

i

else

i

=

i

1

//

Assume the ith item is not in the knapsack

//

Could it be in the optimally packed 7/25/2014

Sabah Binte Noor

(34)

Items: 1: (2,3) 2: (3,4) 3: (4,5) 4: (5,6)

Items: 1: (2,3) 2: (3,4) 3: (4,5) 4: (5,6)

0 0

0 0 0

0 0 0 0 0 0

0 1 2 3

4 5

0 1 2 3

4 i\W

i=4 k= 5

bi=6 wi=5

V[i,k] = 7

V[i1,k] =7

3 3 3 3

0 3 4 4 7

0 3 4

i=n, k=W

while i,k > 0

if V[i,k]  V[i1,k] then

mark the ith item as in the knapsack

i = i1, k = k-wi

else i = i1

5 7

0 3 4 5 7

Finding the Items

7/25/2014

Sabah Binte Noor

(35)

Items: 1: (2,3) 2: (3,4) 3: (4,5) 4: (5,6)

Items: 1: (2,3) 2: (3,4) 3: (4,5) 4: (5,6)

0 0

0 0 0

0 0 0 0 0 0

0 1 2 3

4 5

0 1 2 3

4 i\W

i=4 k= 5 bi=6 wi=5

V[i,k] = 7

V[i1,k] =7

3 3 3 3

0 3 4 4 7

0 3 4

i=n, k=W while i,k > 0

if V[i,k]  V[i1,k] then

mark the ith item as in the knapsack

i = i1, k = k-wi

else i = i1

5 7

0 3 4 5 7

Finding the Items

(36)

Items: 1: (2,3) 2: (3,4) 3: (4,5) 4: (5,6)

Items: 1: (2,3) 2: (3,4) 3: (4,5) 4: (5,6)

0 0

0 0 0

0 0 0 0 0 0

0 1 2 3

4 5

0 1 2 3

4 i\W

i=3

k= 5 bi=5 wi=4

V[i,k] = 7

V[i1,k] =7

3 3 3 3

0 3 4 4 7

0 3 4

i=n, k=W while i,k > 0

if V[i,k]  V[i1,k] then

mark the ith item as in the knapsack

i = i1, k = k-wi

else i = i1

5 7

0 3 4 5 7

Finding the Items

7/25/2014

Sabah Binte Noor

(37)

Items: 1: (2,3) 2: (3,4) 3: (4,5) 4: (5,6)

Items: 1: (2,3) 2: (3,4) 3: (4,5) 4: (5,6)

0 0

0 0 0

0 0 0 0 0 0

0 1 2 3

4 5

0 1 2 3

4 i\W

i=2

k= 5 bi=4 wi=3

V[i,k] = 7

V[i1,k] =3

k  wi=2

3 3 3 3

0 3 4 4 7

0 3 4

i=n, k=W while i,k > 0

if V[i,k]  V[i1,k] then

mark the ith item as in the knapsack

i = i1, k = k-wi

else i = i1

5 7

0 3 4 5 7

7

Finding the Items

(38)

Items: 1: (2,3) 2: (3,4) 3: (4,5) 4: (5,6)

Items: 1: (2,3) 2: (3,4) 3: (4,5) 4: (5,6)

0 0

0 0 0

0 0 0 0 0 0

0 1 2 3

4 5

0 1 2 3

4

i\W i=1

k= 2

bi=3 wi=2

V[i,k] = 3

V[i1,k] =0

k  wi=0

3 3 3 3

0 3 4 4 7

0 3 4

i=n, k=W while i,k > 0

if V[i,k]  V[i1,k] then

mark the ith item as in the knapsack

i = i1, k = k-wi

else i = i1

5 7

0 3 4 5 7

3

Finding the Items

7/25/2014

Sabah Binte Noor

(39)

Items: 1: (2,3) 2: (3,4) 3: (4,5) 4: (5,6)

Items: 1: (2,3) 2: (3,4) 3: (4,5) 4: (5,6)

0 0

0 0 0

0 0 0 0 0 0

0 1 2 3

4 5

0 1 2 3

4 i\W

3 3 3 3

0 3 4 4 7

0 3 4

i=n, k=W

while i,k > 0

if V[i,k]  V[i1,k] then

mark the nth item as in the knapsack

i = i1, k = k-wi

else i = i1

5 7

0 3 4 5 7

i=0 k= 0

The optimal knapsack

should contain {1, 2}

Finding the Items

(40)

Items: 1: (2,3) 2: (3,4) 3: (4,5) 4: (5,6)

Items: 1: (2,3) 2: (3,4) 3: (4,5) 4: (5,6)

0 0

0 0 0

0 0 0 0 0 0

0 1 2 3

4 5

0 1 2 3

4 i\W

3 3 3 3

0 3 4 4 7

0 3 4

i=n, k=W while i,k > 0

if V[i,k]  V[i1,k] then

mark the nth item as in the knapsack

i = i1, k = k-wi

else i = i1

5 7

0 3 4 5 7

The optimal knapsack

should contain {1, 2}

7 3

Finding the Items

7/25/2014

Sabah Binte Noor

(41)

Memoization (Memory Function

Method)

Goal:

Solve only subproblems that are necessary and solve it only

once

Memoization is another way to deal with overlapping

subproblems in dynamic programming

With memoization, we implement the algorithm recursively:

 If we encounter a new subproblem, we compute and store

the solution.

 If we encounter a subproblem we have seen, we look up the

answer

Most useful when the algorithm is easiest to implement

recursively

 Especially if we do not need solutions to all subproblems.

(42)

0-1 Knapsack Memory Function

Algorithm

for i = 1 to n

for w = 1 to W V[i,w] = -1

for w = 0 to W V[0,w] = 0

for i = 1 to n V[i,0] = 0

7/25/2014

Sabah Binte Noor

42

MFKnapsack(i, w) if V[i,w] < 0

if w < wi

value = MFKnapsack(i-1, w) else

value = max(MFKnapsack(i-1, w), bi+ MFKnapsack(i-1, w-wi))

References

Related documents

As shown in this study, loyalty to the organization resulting from merger or acquisition has different intensity level for employees in different hierarchical

 Transportation  activities  include  personnel  and   freight  movements  and  mobile  plant  activities..  Intertwined  with  these  BMPs  are  enforceable

This is the recurring motto of the unedited treatise Diez privilegios para mujeres preñadas 4 (Ten Privileges for Pregnant Women), written in 1606 by the Spanish physician

6 the distribution of possible food security outcomes for pastoralist regions based on this combination of rainfall and forecast is noticeably different for forecasts of

— Sutural angle of elytra without small tooth; head, antennae, scutellum, legs, and venter (except abdominal sterna laterally) black; pronotum yellow with disc black from base to

PerformanceIN grants you permission to store and print from this material for your own personal and commercial use.. No part of this publication may be reproduced without

Itron wideband systems operate across 120 channels and are designed to receive up to 120 separate transmissions simultaneously, each at 37.5 kbps (kbps = kilo bits per second)