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自动安装pip
Apr 24 Python
wxPython事件驱动实例详解
Sep 28 Python
Python实现单词拼写检查
Apr 25 Python
Python连接数据库学习之DB-API详解
Feb 07 Python
解决python3 urllib中urlopen报错的问题
Mar 25 Python
局域网内python socket实现windows与linux间的消息传送
Apr 19 Python
Python numpy数组转置与轴变换
Nov 15 Python
Python定义函数实现累计求和操作
May 03 Python
PyQt5 文本输入框自动补全QLineEdit的实现示例
May 13 Python
Python调用C/C++的方法解析
Aug 05 Python
python+selenium+chrome实现淘宝购物车秒杀自动结算
Jan 07 Python
python实现三阶魔方还原的示例代码
Apr 28 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
php文件打包 下载之使用PHP自带的ZipArchive压缩文件并下载打包好的文件
2012/06/13 PHP
php简单socket服务器客户端代码实例
2015/05/18 PHP
php使用Jpgraph绘制复杂X-Y坐标图的方法
2015/06/10 PHP
WordPress中转义HTML与过滤链接的相关PHP函数使用解析
2015/12/22 PHP
PHP在linux上执行外部命令的方法
2017/02/06 PHP
PHP仿qq空间或朋友圈发布动态、评论动态、回复评论、删除动态或评论的功能(上)
2017/05/26 PHP
PHP实现的AES双向加密解密功能示例【128位】
2018/09/03 PHP
解决laravel资源加载路径设置的问题
2019/10/14 PHP
细品javascript 寻址,闭包,对象模型和相关问题
2009/04/27 Javascript
javascript 读取XML数据,在页面中展现、编辑、保存的实现
2009/10/27 Javascript
jquery选择器排除某个DOM元素的方法(实例演示)
2014/04/25 Javascript
如何在node的express中使用socket.io
2014/12/15 Javascript
jQuery筛选数组之grep、each、inArray、map的用法及遍历json对象
2016/06/20 Javascript
AngularJS基础 ng-repeat 指令简单示例
2016/08/03 Javascript
Vue开发中整合axios的文件整理
2017/04/29 Javascript
基于VUE选择上传图片并页面显示(图片可删除)
2017/05/25 Javascript
Node.js中 __dirname 的使用介绍
2017/06/19 Javascript
Angularjs按需查询实例代码
2017/10/30 Javascript
node.js爬虫框架node-crawler初体验
2020/10/29 Javascript
Python随手笔记第一篇(2)之初识列表和元组
2016/01/23 Python
深入了解Python数据类型之列表
2016/06/24 Python
python中logging包的使用总结
2018/02/28 Python
python中的不可变数据类型与可变数据类型详解
2018/09/16 Python
python使用原始套接字发送二层包(链路层帧)的方法
2019/07/22 Python
python异常处理和日志处理方式
2019/12/24 Python
Python中实现输入一个整数的案例
2020/05/03 Python
python ETL工具 pyetl
2020/06/07 Python
Python基于staticmethod装饰器标示静态方法
2020/10/17 Python
海淘母婴商城:国际妈咪
2016/07/23 全球购物
机电一体化大学生求职信
2013/11/08 职场文书
仓管员岗位职责范文
2013/11/08 职场文书
小学新学期寄语
2014/04/02 职场文书
茶楼服务员岗位职责
2015/02/09 职场文书
基层组织建设年活动总结
2015/05/09 职场文书
致三级跳运动员加油稿
2015/07/21 职场文书
酒店员工管理制度
2015/08/05 职场文书