动态规划_01背包问题(Java实现)(Java模板)

动态规划有很多问题

百度百科:
"
动态规划一般可分为线性动规,区域动规,树形动规,背包动规四类。
举例:
线性动规:拦截导弹,合唱队形,挖地雷,建学校,剑客决斗等;
区域动规:石子合并, 加分二叉树,统计单词个数,炮兵布阵等;
树形动规:贪吃的九头龙,二分查找树,聚会的欢乐,数字三角形等;
背包问题:01背包问题,完全背包问题,分组背包问题,二维背包,装箱问题,挤牛奶(同济ACM第1132题)等;
"

01背包问题不算难,这里主要写一下java的模板,给以后自己复习和刷题使用。
想要学习怎么解决背包问题的,这里我推荐一本书《算法图解》,真的非常通俗易懂!下载链接:算法图解,直接跳到第九章动态规划看。
另外还有一篇微信公众号文章也不错 漫画:什么是动态规划?不过文章最后的动态规划的代码有问题的。

/*
 * 0-1背包问题:给定一组物品,每种物品都有自己的重量和价格,在限定的总重量内,我们如何选择,才能使得物品的总价格最高
 * 
 * 以下用一个问题作为案例
 * 挖矿问题
 * 5座金矿,每座金矿的储量不同,需要参与挖矿的工人数也不同。
 * 参与挖矿的总工人数是10,每座金矿要么全挖,要么不挖,不能
 * 派一半人挖一半矿。求应选择挖哪几座金矿,才能得到尽可能多的黄金,(求能挖的最多黄金)。
 * 金矿数据:1:500金/5人;     2:400/5;     3:300/4;    4:200/3;     5:350/3
 **/
package Dynamic_Program;

public class DP_01背包问题 {
	public static void main(String[] args) {
		int weight = 10; // 工人数量(就是背包问题中的背包重量)
		int 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值