动态规划之背包问题01——Java实现
2017-08-13 11:27
676 查看
public class BackPack { public static void main(String[] args) { int m = 10; int n = 3; int w[] = {3, 4, 5}; int p[] = {4, 5, 6}; int c[][] = BackPack_Solution(m, n, w, p); for (int i = 1; i <=n; i++) { for (int j = 1; j <=m; j++) { System.out.print(c[i][j]+"\t"); if(j==m){ System.out.println(); } } } //printPack(c, w, m, n); } /** * @param m 表示背包的最大容量 * @param n 表示商品个数 * @param w 表示商品重量数组 * @param p 表示商品价值数组 */ public static int[][] BackPack_Solution(int m, int n, int[] w, int[] p) { //c[i][v]表示前i件物品恰放入一个重量为m的背包可以获得的最大价值 int c[][] = new int[n + 1][m + 1]; for (int i = 0; i < n + 1; i++) c[i][0] = 0; for (int j = 0; j < m + 1; j++) c[0][j] = 0; for (int i = 1; i < n + 1; i++) { for (int j = 1; j < m + 1; j++) { //当物品为i件重量为j时,如果第i件的重量(w[i-1])小于重量j时,c[i][j]为下列两种情况之一: //(1)物品i不放入背包中,所以c[i][j]为c[i-1][j]的值 //(2)物品i放入背包中,则背包剩余重量为j-w[i-1],所以c[i][j]为c[i-1][j-w[i-1]]的值加上当前物品i的价值 if (w[i - 1] <= j) { if (c[i - 1][j] < (c[i - 1][j - w[i - 1]] + p[i - 1])) c[i][j] = c[i - 1][j - w[i - 1]] + p[i - 1]; else c[i][j] = c[i - 1][j]; } else c[i][j] = c[i - 1][j]; } } return c; }
相关文章推荐
- 动态规划之背包问题01--java实现
- 动态规划之背包问题01——Java实现
- 动态规划(背包问题)java实现
- 动态规划之背包问题——Java实现
- 0-1背包问题的动态规划实现
- 动态规划7:砝码和种类优化成01背包问题
- 01背包问题之动态规划
- 动态规划的两个经典问题--01背包
- 01背包问题Java实现
- 01背包问题动态规划详解(转载)
- 0-1背包问题动态规划代码实现(C++实现)
- 01背包问题 -- 经典动态规划题
- 【初学动态规划】之01背包问题
- 最大报销额(动态规划:01背包问题变形)
- 01背包问题的动态规划解法
- 动态规划解决矩阵链乘问题的java编码实现
- 算法导论学习笔记(十三):动态规划(三):01背包问题
- 动态规划01背包问题
- Java求解,输入两个整数n和m,从数列1,2,3,……n中随意取几个数,使其和等于m。要求将所有的可能组合列出来(背包动态规划问题求解)
- 动态规划_01背包问题_Java实现