解题思路:

注意事项:

参考代码:

import java.util.Scanner;


public class dp解决01背包问题 {


public static void main(String[] args) {

// TODO Auto-generated method stub

Scanner sc = new Scanner(System.in);

      int n = sc.nextInt();//物品的数量

      int m = sc.nextInt();//最大的装载重量

      int[] w = new int[n];

      int[] v = new int[n];

      for(int i = 0;i<n;i++) {

     w[i] = sc.nextInt();

     v[i] =sc.nextInt();

      }

      int res = dp(w,v,n,m);

      System.out.println(res);

}


public static int dp(int[] w,int[] v,int n,int m) {

int[][] dp = new int[n][m+1];

//初始化第一行数据

for(int i =0;i<=m;i++) {

if(i>=w[0]) {

dp[0][i] = v[0];

}else {

dp[0][i] = 0;

}

}

//算出其他行的数据

for(int row = 1;row<n;row++) {

for(int col = 0;col<=m;col++) {

if(col>=w[row]) {//背包的容量大于这个物品的重量

dp[row][col] = Math.max(v[row]+dp[row-1][col-w[row]], dp[row-1][col]);

}else {

dp[row][col] = dp[row-1][col];

}

}

}

return dp[n-1][m];

}

}


点赞(0)
 

0.0分

0 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论