数据结构-背包问题.doc

上传者: 43934844 | 上传时间: 2022-07-11 14:06:29 | 文件大小: 73KB | 文件类型: DOC
背包问题的求解 1.问题描述 假设有一个能装入总体积为T的背包和n件体积分别为w1,w2,…wn的物品,能否从n件物品 中挑选若干件恰好装满背包,即使w1+w2+…+wm=T,要求找出所有满足上述条件的解。 例如:当T=10,各件物品的体积{1,8,4,3,5,2}时,可找到下列4组解: (1,4,3,2) (1,4,5) (8,2) (3,5,2)。 2.实现提示 可利用回溯法的设计思想来解决背包问题。首先,将物品排成一列,然后,顺序选取物 品装入背包,若已选取第i件物品后未满,则继续选取第i+1件,若该件物品"太大"不能 装入,则弃之,继续选取下一件,直至背包装满为止。 如果在剩余的物品中找不到合适的物品以填满背包,则说明"刚刚"装入的物品"不合适" ,应将它取出"弃之一边",继续再从"它之后"的物品中选取,如此重复,直到求得满足 条件的解,或者无解。 由于回溯求解的规则是"后进先出",自然要用到"栈"。 进一步考虑:如果每件物品都有体积和价值,背包又有大小限制,求解背包中存放物品 总价值最大的问题解---最优解或近似最优解。 3. 题目源代码 #define maxsize 10

文件下载

评论信息

免责申明

【只为小站】的资源来自网友分享,仅供学习研究,请务必在下载后24小时内给予删除,不得用于其他任何用途,否则后果自负。基于互联网的特殊性,【只为小站】 无法对用户传输的作品、信息、内容的权属或合法性、合规性、真实性、科学性、完整权、有效性等进行实质审查;无论 【只为小站】 经营者是否已进行审查,用户均应自行承担因其传输的作品、信息、内容而可能或已经产生的侵权或权属纠纷等法律责任。
本站所有资源不代表本站的观点或立场,基于网友分享,根据中国法律《信息网络传播权保护条例》第二十二条之规定,若资源存在侵权或相关问题请联系本站客服人员,zhiweidada#qq.com,请把#换成@,本站将给予最大的支持与配合,做到及时反馈和处理。关于更多版权及免责申明参见 版权及免责申明