c语言贪心算法0-1背包问题,贪心算法 - 0/1背包问题

本文介绍了使用C语言解决0-1背包问题的贪心算法,详细解析了问题描述、最优性原理和递推关系,并提供了C++代码示例,展示动态规划求解过程和回溯策略,揭示算法的时间复杂度。
摘要由CSDN通过智能技术生成

1、问题描述:

给定n种物品和一背包。物品i的重量是wi,其价值为vi,背包的容量为C。问:应如何选择装入背包的物品,使得装入背包中物品的总价值最大?

形式化描述:给定c >0, wi >0, vi >0 , 1≤i≤n.要求找一n元向量(x1,x2,…,xn,), xi∈{0,1}, ∋ ∑ wi xi≤c,且∑ vi xi达最大.即一个特殊的整数规划问题。

1363491053_2831.jpg

2、最优性原理:

设(y1,y2,…,yn)是 (3.4.1)的一个最优解.则(y2,…,yn)是下面相应子问题的一个最优解:

1363491194_4435.jpg

证明:使用反证法。若不然,设(z2,z3,…,zn)是上述子问题的一个最优解,而(y2,y3,…,yn)不是它的最优解。显然有

∑vizi > ∑viyi   (i=2,…,n)

且                           w1y1+ ∑wizi<= c

因此                       v1y1+ ∑vizi (i=2,…,n) > ∑ viyi, (i=1,…,n)

说明(y1,z2, z3,…,zn)是(3.4.1)0-1背包问题的一个更优解,导出(y1,y2,…,yn)不是背包问题的最优解,矛盾。

3、递推关系:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值