原题链接:蓝桥杯算法提高VIP-01背包
解题思路:
简单的0-1背包问题。
注意事项:
注意第二层循环时,j要从m到weight[i]依次递减下去。不然会出现同一物品被选多次的场景。(该种情况是完全背包的解题方法)
参考代码:
import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; public class Main { public static void main(String[] args) throws IOException { BufferedReader reader = new BufferedReader(new InputStreamReader(System.in)); String[] s = reader.readLine().split(" "); int n = Integer.parseInt(s[0]);//物品的个数 int m = Integer.parseInt(s[1]);//背包的重量 int[] weight = new int[n + 1]; int[] value = new int[n + 1]; for (int i = 1; i <= n; i++) { String[] s1 = reader.readLine().split(" "); weight[i] = Integer.parseInt(s1[0]); value[i] = Integer.parseInt(s1[1]); } int dp[] = new int[m + 1]; for (int i = 1; i <= n; i++) { for (int j = m; j >= weight[i]; j--) { dp[j] = Math.max(dp[j], dp[j - weight[i]] + value[i]); } } System.out.println(dp[m]); } }
0.0分
1 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复