标题:急!!新背包求解
只看楼主
xiho
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2006-3-3
 问题点数:0 回复次数:1 
急!!新背包求解
假设有一个能装入总体积为T的背包和n件体积分别为w1 , w2 , … , wn 的物品,能否从n件物品中挑选若干件恰好装满背包,即使w1 +w2 + … + wn=T,要求找出所有满足上述条件的解。例如:当T=10,各件物品的体积{1,8,4,3,5,2}时,可找到下列4组解:(1,4,3,2)
(1,4,5)
(8,2)
(3,5,2)。
提示:可利用回溯法的设计思想来解决背包问题。首先将物品排成一列,然后顺序选取物品装入背包,假设已选取了前i 件物品之后背包还没有装满,则继续选取第i+1件物品,若该件物品“太大”不能装入,则弃之而继续选取下一件,直至背包装满为止。但如果在剩余的物品中找不到合适的物品以填满背包,则说明“刚刚”装入背包的那件物品“不合适”,应将它取出“弃之一边”,继续再从“它之后”的物品中选取,如此重复,,直至求得满足条件的解,或者无解。
由于回溯求解的规则规则是“后进先出”因此自然要用到栈。

急求C\C++的完整程序,给出一个详细的算法也可以,各位大侠帮帮小弟,谢谢大家

搜索更多相关主题的帖子: 背包 求解 
2006-06-03 19:47
zinking
Rank: 7Rank: 7Rank: 7
等 级:贵宾
威 望:35
帖 子:916
专家分:0
注 册:2004-12-5
得分:0 
对阿,回溯法。

http://kongfuziandlife. http://codeanddesign.
2006-06-03 21:51



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-69581-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.278694 second(s), 8 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved