解01背包问题的动态规划算法.doc

解01背包问题的动态规划算法.doc

解0/1背包问题的动态规划算法 摘要:本文通过研究动态规划原理,提出了根据该原理解决0/1背包问题的方法与算法实现,并对算法的正确性作了验证.观察程序运行结果,发现基于动态规划的算法能够得到正确的决策方案且比穷举法有效. 关键字:动态规划;0/1背包;约束条件;序偶;决策序列;支配规则 1、引 言 科学研究与工程实践中,常常会遇到许多优化问题,而有这么一类问题,它们的活动过程可以分为若干个阶段,但整个过程受到某一条件的限制。这若干个阶段的不同决策的组合就构成一个完整的决策。0/1背包问题就是一个典型的在资源有限的条件下,追求总的收益最大的资源有效分配的优化问题。 对于0/1背包问题,我们可以这样描述:设有一确定容量为C的包及两个向量C’=(S1,S2,……,Sn)和P=(P1,P2,……,PN),再设X为一整数集合,即X=1,2,3,……,N,X为SI、PI的下标集,T为X的子集,那么问题就是找出满足约束条件∑Si〈=C,使∑PI获得最大的子集T。在实际运用中,S的元素可以是N个经营项目各自所消耗的资源,C可以是所能提供的资源总量,P的元素可是人们从各项项目中得到的利润。 0/1背包问题是工程问题的典型概括,怎么样高效求出最优决策,是人们关心的问题。 2、求解问题的动态规划原理与算法 2.1动态规划原理的描述 求解问题的动态规划有向前处理法向后处理法两种,这里使用向前处理

您可能关注的文档

文档评论(0)

1亿VIP精品文档

相关文档