Explain 0/1 Knapsack problem with dynamic programming approach. Source instance of 0/1 knapsack problem using n=4 (w1,w2,w3,w4)=(6,8,4,2) and (p1,p2,p3,p4)=(10,5,18,12) and capacity of knapsack is 10. code example
Example: knapsack algorithm in python
def knapSack(W, wt, val, n):
K = [[0 for x in range(W + 1)] for x in range(n + 1)]
for i in range(n + 1):
for w in range(W + 1):
if i == 0 or w == 0:
K[i][w] = 0
elif wt[i-1] <= w:
K[i][w] = max(val[i-1] + K[i-1][w-wt[i-1]], K[i-1][w])
else:
K[i][w] = K[i-1][w]
return K[n][W]
val = [50,100,150,200]
wt = [8,16,32,40]
W = 64
n = len(val)
print(knapSack(W, wt, val, n))