Python基于贪心算法解决背包问题示例


Posted in Python onNovember 27, 2017

本文实例讲述了Python基于贪心算法解决背包问题。分享给大家供大家参考,具体如下:

贪心算法(又称贪婪算法)是指,在对问题求解时,总是做出在当前看来是最好的选择。也就是说,不从整体最优上加以考虑,他所做出的是在某种意义上的局部最优解。

贪心算法不是对所有问题都能得到整体最优解,关键是贪心策略的选择,选择的贪心策略必须具备无后效性,即某个状态以前的过程不会影响以后的状态,只与当前状态有关。

完全背包问题:给定n个物品和一个容量为C的背包,物品i的重量是Wi,其价值为Vi,背包问题是如何选择入背包的物品,使得装入背包的物品的总价值最大,与0-1背包的区别是,在完全背包问题中,可以将物品的一部分装入背包,但不能重复装入。

设计算法的思路很简单,计算物品的单位价值,然后尽可能多的将单位重量价值高的物品放入背包中。

python实现代码如下:

# coding=gbk
# 完全背包问题,贪心算法
import time
__author__ = 'ice'
class goods:
  def __init__(self, goods_id, weight=0, value=0):
    self.id = goods_id
    self.weight = weight
    self.value = value
# 不适用于0-1背包
def knapsack(capacity=0, goods_set=[]):
  # 按单位价值量排序
  goods_set.sort(key=lambda obj: obj.value / obj.weight, reverse=True)
  result = []
  for a_goods in goods_set:
    if capacity < a_goods.weight:
      break
    result.append(a_goods)
    capacity -= a_goods.weight
  if len(result) < len(goods_set) and capacity != 0:
    result.append(goods(a_goods.id, capacity, a_goods.value * capacity / a_goods.weight))
  return result
some_goods = [goods(0, 2, 4), goods(1, 8, 6), goods(2, 5, 3), goods(3, 2, 8), goods(4, 1, 2)]
start_time = time.clock()
res = knapsack(6, some_goods)
end_time = time.clock()
print('花费时间:' + str(end_time - start_time))
for obj in res:
  print('物品编号:' + str(obj.id) + ' ,放入重量:' + str(obj.weight) + ',放入的价值:' + str(obj.value), end=',')
  print('单位价值量为:' + str(obj.value / obj.weight))
# 花费时间:2.2807240614677942e-05
# 物品编号:3 ,放入重量:2,放入的价值:8,单位价值量为:4.0
# 物品编号:0 ,放入重量:2,放入的价值:4,单位价值量为:2.0
# 物品编号:4 ,放入重量:1,放入的价值:2,单位价值量为:2.0
# 物品编号:1 ,放入重量:1,放入的价值:0.75,单位价值量为:0.75

希望本文所述对大家Python程序设计有所帮助。

Python 相关文章推荐
python UNIX_TIMESTAMP时间处理方法分析
Apr 18 Python
Python实现的排列组合计算操作示例
Oct 13 Python
python @property的用法及含义全面解析
Feb 01 Python
Python实现的寻找前5个默尼森数算法示例
Mar 25 Python
Python实现E-Mail收集插件实例教程
Feb 06 Python
浅谈Django2.0 加xadmin踩的坑
Nov 15 Python
python 实现简单的FTP程序
Dec 27 Python
python isinstance函数用法详解
Feb 13 Python
python 轮询执行某函数的2种方式
May 03 Python
python实现126邮箱发送邮件
May 20 Python
Keras之fit_generator与train_on_batch用法
Jun 17 Python
Django多数据库联用实现方法解析
Nov 12 Python
Python标准模块--ContextManager上下文管理器的具体用法
Nov 27 #Python
利用信号如何监控Django模型对象字段值的变化详解
Nov 27 #Python
深入理解Python中range和xrange的区别
Nov 26 #Python
PyCharm在win10的64位系统安装实例
Nov 26 #Python
python shell根据ip获取主机名代码示例
Nov 25 #Python
python自动裁剪图像代码分享
Nov 25 #Python
分享一个简单的python读写文件脚本
Nov 25 #Python
You might like
oracle资料库函式库
2006/10/09 PHP
php摘要生成函数(无乱码)
2012/02/04 PHP
Laravel框架实现利用监听器进行sql语句记录功能
2018/06/06 PHP
js实现键盘控制DIV移动的方法
2015/01/10 Javascript
微信小程序 实例开发总结
2017/04/26 Javascript
微信小程序 跳转传递数据的实例
2017/07/06 Javascript
JavaScript设计模式之单例模式简单实例教程
2018/07/02 Javascript
详解vue2.0+axios+mock+axios-mock+adapter实现登陆
2018/07/19 Javascript
Vue中的情侣属性$dispatch和$broadcast详解
2019/03/07 Javascript
详解小程序如何动态绑定点击的执行方法
2019/11/26 Javascript
easyUI 实现的后台分页与前台显示功能示例
2020/06/01 Javascript
vue双击事件2.0事件监听(点击-双击-鼠标事件)和事件修饰符操作
2020/07/27 Javascript
windows系统下Python环境的搭建(Aptana Studio)
2017/03/06 Python
利用Python求阴影部分的面积实例代码
2018/12/05 Python
python分数表示方式和写法
2019/06/26 Python
python读取xml文件方法解析
2020/08/04 Python
python 无损批量压缩图片(支持保留图片信息)的示例
2020/09/22 Python
pandas apply使用多列计算生成新的列实现示例
2021/02/24 Python
css3实现背景模糊的三种方式(小结)
2020/05/15 HTML / CSS
canvas实现滑动验证的实现示例
2020/08/11 HTML / CSS
G-Form护具官方网站:美国运动保护装备
2019/09/04 全球购物
远程调用的原理
2014/07/05 面试题
医院门卫岗位职责
2013/12/30 职场文书
回门宴新郎答谢词
2014/01/12 职场文书
树转促学习心得体会
2014/09/10 职场文书
个人买房协议书范本
2014/10/06 职场文书
大学生实训报告总结
2014/11/05 职场文书
教师师德表现自我评价
2015/03/05 职场文书
2015年助理工程师工作总结
2015/04/03 职场文书
2015年度校学生会工作总结报告
2015/05/23 职场文书
元旦晚会主持词开场白
2015/05/28 职场文书
2016年9月份红领巾广播稿
2015/12/21 职场文书
如何让2019年上半年的工作总结更出色!
2019/07/01 职场文书
评测 | 大屏显示带收音机的高端音箱,JBL TUNE2便携式插卡音箱实测
2021/04/24 无线电
redis调用二维码时的不断刷新排查分析
2022/04/01 Redis
Python 绘制多因子柱状图
2022/05/11 Python