PHP algorithm analysis: How to use dynamic programming algorithm to solve the 0-1 knapsack problem?
Introduction:
Dynamic programming is an algorithmic idea commonly used to solve optimization problems. In program development, the 0-1 knapsack problem is a classic dynamic programming application scenario. This article will introduce how to use PHP to write a dynamic programming algorithm to solve the 0-1 knapsack problem, and provide specific code examples.
What is the 0-1 knapsack problem?
0-1 knapsack problem is a classic combinatorial optimization problem. The problem is set as follows: There is a backpack with a capacity of C. There are n items, each item has a weight w[i] and a value v[i]. It is required to choose a combination of items to maximize the total value without exceeding the capacity of the backpack.
Dynamic programming solution
The dynamic programming algorithm divides the given problem into a series of sub-problems and stores the optimal solutions of the sub-problems, and finally solves the optimal solution of the entire problem. For the 0-1 knapsack problem, we can use dynamic programming algorithm to solve it.
Algorithm idea:
Traverse items:
Specific code example:
function knapsack($C, $weight, $value, $n) { $dp = array(); for ($i = 0; $i <= $n; $i++) { for ($j = 0; $j <= $C; $j++) { $dp[$i][$j] = 0; } } for ($i = 1; $i <= $n; $i++) { for ($j = 1; $j <= $C; $j++) { if ($weight[$i-1] <= $j) { $dp[$i][$j] = max($value[$i-1] + $dp[$i-1][$j-$weight[$i-1]], $dp[$i-1][$j]); } else { $dp[$i][$j] = $dp[$i-1][$j]; } } } return $dp[$n][$C]; } // 示例输入 $C = 10; // 背包容量 $weight = array(2, 3, 4, 5); // 物品重量 $value = array(3, 4, 5, 6); // 物品价值 $n = count($weight); // 物品数量 // 输出最大价值 echo "背包容量为 " . $C . " 时的最大价值为:" . knapsack($C, $weight, $value, $n);
Code analysis:
knapsack
Accepts four parameters: backpack capacity C, items Weight array weight, item value array value and item quantity n. Conclusion:
By using dynamic programming algorithm to solve the 0-1 knapsack problem, the maximum value that the knapsack can hold can be efficiently solved. In PHP, this algorithm can be implemented by writing appropriate code. This algorithmic idea is not only applicable to the 0-1 knapsack problem, but also can be applied to other similar combinatorial optimization problems.
The above is the detailed content of PHP algorithm analysis: How to use dynamic programming algorithm to solve the 0-1 knapsack problem?. For more information, please follow other related articles on the PHP Chinese website!