def knapsack_max_value(weights, values, capacity):
n = len(weights)
dp = [[0] * (capacity + 1) for _ in range(n + 1)]
for i in range(1, n + 1):
for w in range(1, capacity + 1):
if weights[i - 1] > w:
dp[i][w] = dp[i - 1][w]
else:
dp[i][w] = max(dp[i - 1][w], dp[i - 1][w - weights[i - 1]] + values[i - 1])
return dp[n][capacity]
weights = [10, 20, 30]
values = [60, 100, 120]
capacity = 50
print(knapsack_max_value(weights, values, capacity))