动态规划之背包问题01——Java实现
来源:互联网 发布:域名交易流程 编辑:程序博客网 时间:2024/06/01 08:49
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; }
阅读全文
0 0
- 动态规划之背包问题01——Java实现
- 动态规划之背包问题——Java实现
- 动态规划之背包问题01--java实现
- 动态规划之——背包问题
- 动态规划之0/1背包问题-java实现
- 动态规划之背包问题 python实现
- 动态规划之背包问题(JAVA)
- 动态规划解决01背包问题(java实现)
- 动态规划——01背包问题
- 动态规划——01背包问题
- 动态规划——01背包问题
- 动态规划——01背包问题
- 动态规划—01背包问题
- Java语言之动态规划实现01背包
- 动态规划问题之01背包问题
- 动态规划实现 01背包问题
- 动态规划--01背包问题 C++实现
- 动态规划之01背包问题
- redis和mongledb
- HDU 6113 度度熊的01世界 【DFS】(2017"百度之星"程序设计大赛
- 指针和指针的指针
- github使用笔记
- Java数据结构和算法(一)--顺序表、链表、静态链表
- 动态规划之背包问题01——Java实现
- 数字验证码
- JS核心
- Android基础_软件的国际化 Acitivity(七)
- 重载赋值运算符
- Poj3070 Fibonacci (矩阵快速幂)
- 在CentOS7上部署OpenStack 步骤详解
- BZOJ.1036 [ZJOI2008]树的统计Count ( 点权树链剖分 线段树维护和与最值)
- UVA1635IrrelevantElement