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实现博客文章爬虫示例
Feb 26 Python
使用grappelli为django admin后台添加模板
Nov 18 Python
python定向爬取淘宝商品价格
Feb 27 Python
Python使用OpenCV进行标定
May 08 Python
Django 开发环境配置过程详解
Jul 18 Python
详解python中的模块及包导入
Aug 30 Python
django-crontab 定时执行任务方法的实现
Sep 06 Python
python打印直角三角形与等腰三角形实例代码
Oct 20 Python
python利用datetime模块计算程序运行时间问题
Feb 20 Python
使用Pycharm分段执行代码
Apr 15 Python
Python异常类型以及处理方法汇总
Jun 05 Python
pytorch实现加载保存查看checkpoint文件
Jul 15 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游戏编程25个脚本代码
2011/02/08 PHP
php中关于codeigniter的xmlrpc的类在进行数据交换时的类型问题
2011/07/03 PHP
php中filter_input函数用法分析
2014/11/15 PHP
CI框架扩展系统核心类的方法分析
2016/05/23 PHP
Mootools 1.2教程 滚动条(Slider)
2009/09/15 Javascript
javascript的字符串按引用复制和传递,按值来比较介绍与应用
2012/12/28 Javascript
jquery获取焦点和失去焦点事件代码
2013/04/21 Javascript
JS注册/移除事件处理程序(ExtJS应用程序设计实战)
2013/05/07 Javascript
js中document.write使用过程中的一点疑问解答
2014/03/20 Javascript
JavaScript-RegExp对象只能使用一次问题解决方法
2014/06/23 Javascript
vue通过watch对input做字数限定的方法
2017/07/13 Javascript
JavaScript函数中的this四种绑定形式
2017/08/15 Javascript
JavaScript编程设计模式之构造器模式实例分析
2017/10/25 Javascript
写一个移动端惯性滑动&amp;回弹Vue导航栏组件 ly-tab
2018/03/06 Javascript
vue中手机号,邮箱正则验证以及60s发送验证码的实例
2018/03/16 Javascript
详解处理Vue单页面应用SEO的另一种思路
2018/11/09 Javascript
结合axios对项目中的api请求进行封装操作
2020/09/21 Javascript
JS如何操作DOM基于表格动态展示数据
2020/10/15 Javascript
python快速排序代码实例
2013/11/21 Python
python获取本机mac地址和ip地址的方法
2015/04/29 Python
利用Python破解验证码实例详解
2016/12/08 Python
Python安装官方whl包和tar.gz包的方法(推荐)
2017/06/04 Python
pip matplotlib报错equired packages can not be built解决
2018/01/06 Python
Python字典的核心底层原理讲解
2019/01/24 Python
python实现手机销售管理系统
2019/03/19 Python
python 扩展print打印文件路径和当前时间信息的实例代码
2019/10/11 Python
python logging日志模块原理及操作解析
2019/10/12 Python
利用Python自动化操作AutoCAD的实现
2020/04/01 Python
利用CSS3实现文本框的清除按钮相关的一些效果
2015/06/23 HTML / CSS
canvas学习笔记之绘制简单路径
2019/01/28 HTML / CSS
XML文档面试题
2015/08/05 面试题
开业庆典主持词
2014/03/21 职场文书
送温暖献爱心活动总结
2014/07/08 职场文书
事业单位年度考核个人总结
2015/02/12 职场文书
民间借贷借条范本
2015/05/25 职场文书
Django数据库(SQlite)基本入门使用教程
2022/07/07 Python