Recursion and Dynamic Programming
0/1 Knapsack (Small)
Fill a small 0/1 knapsack table where each row decides whether one more item is available.
Algorithm
@steps
- Create a table with one extra row for using zero items.
- Process the four items in fixed order.
- For each capacity, inherit when the item is too heavy.
- Otherwise compare
skipandtakefrom the previous row. - Print the best value and the full deterministic table. @end @complexity
- Time: O(item_count * capacity)
- Space: O(item_count * capacity) @end
state transition
`dp[i][w]` compares skipping item `i` with taking it and reading the remaining capacity from the previous row.
PHP DSA Implementation
basic.php
<?php
function row_string($row) { return "[" . implode(", ", $row) . "]"; }
function table_string($table) { return "[" . implode(", ", array_map("row_string", $table)) . "]"; }
$weights = [2, 3, 4, 5];
$values = [3, 4, 5, 6];
$capacity = 5;
$dp = array_fill(0, count($weights) + 1, array_fill(0, $capacity + 1, 0));
for ($item = 1; $item <= count($weights); $item++) {
$weight = $weights[$item - 1];
$value = $values[$item - 1];
for ($cap = 0; $cap <= $capacity; $cap++) {
if ($weight > $cap) $dp[$item][$cap] = $dp[$item - 1][$cap];
else {
$skip = $dp[$item - 1][$cap];
$take = $value + $dp[$item - 1][$cap - $weight];
$dp[$item][$cap] = max($skip, $take);
}
}
}
echo $dp[count($weights)][$capacity] . PHP_EOL;
echo table_string($dp) . PHP_EOL;
?>
@end @output 7 [[0, 0, 0, 0, 0, 0], [0, 0, 3, 3, 3, 3], [0, 0, 3, 4, 4, 7], [0, 0, 3, 4, 5, 7], [0, 0, 3, 4, 5, 7]] @end