贪心算法--装箱问题

问题描述

n个物品体积分别为:V1、V2、…、Vn。将这n个物品装入若干个体积为V的箱子(约定每个物品的体积Vi都不超过V)。要求:使用的箱子尽可能少。

贪心准则

1)将所有物品按体积大小降序排列;
2)每次都保证将未放入箱子中体积最大的物品优先放入已打开的箱子中。

存储结构

分析:
物品个数固定,采用数组存储;所需箱子个数不确定,箱子采用链表存储;每个箱子里能装的物品个数也不确定,同样采用链表存储。
1)物品
形式:数组(goods)
类型:物体编号(gno)、物体体积(gv)—>结构体变量GOODS
2)箱子
形式:链表(hg)
类型:剩余体积(remainder)、指向物品结点的头指针(hg)、指向下一个箱子的指针域(next)—>结构体变量BOX
3)物品链结点
形式:链表(head)
类型:物品编号(gnum)、指向下一个物品的指针域(link)—>结构体变量GNODE

简述算法实现

按照物品体积降序排列之后,每拿出一个物品,从第一个箱子开始遍历,寻找能装下的那个箱子,装箱;再拿下一件物品。。。直至物品全部装箱。最终实现的结果大致如下:
示意图:
这里写图片描述

若要查找每个箱子装的物品编号,遍历

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值