python 贪心算法的实现


Posted in Python onSeptember 18, 2020

贪心算法

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

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

基本思路

思想

贪心算法的基本思路是从问题的某一个初始解出发一步一步地进行,根据某个优化测度,每一步都要确保能获得局部最优解。每一步只考虑一个数据,他的选取应该满足局部优化的条件。若下一个数据和部分最优解连在一起不再是可行解时,就不把该数据添加到部分解中,直到把所有数据枚举完,或者不能再添加算法停止 。

步骤

  1. 遍历初始集合X中的备选元素
  2. 利用贪心策略在X中确定一个元素,并将其加入到可行解S中
  3. 得到可行解S

python 贪心算法的实现

P即为贪心策略,用来选择符合条件的元素。

例子——硬币找零

假设某国硬币面值有1,5,10,25,100元五种面额,若店员为顾客找零时,需要给顾客找零a=36元,求硬币数最少的情况。

python 贪心算法的实现

这里我们的贪心策略为:

先找到最接近a的值,然后对a进行更新,然后进行循环。

代码实现

def shortNum(a):
  coins = [1,5,10,25,100]
  out = []
  coins = coins[::-1]

  for i in coins:
    num = a//i
    out=out+[i,]*num
    a = a-num*i
    if a<=0:
      break
  return out
a = 36
print(shortNum(a))

例子——任务规划

问题描述:

输入为任务集合X= [r1,r2,r3,...,rn],每个任务ri,都对应着一个起始时间ai与结束时间bi

要求输出为最多的相容的任务集。

python 贪心算法的实现

 如上图,r1与r2相容,r3与r1和r2都不相容。

那么这里的贪心策略我们可以设为:

  1. 先将结束时间最短的任务加入到S中,
  2. 再从剩下的任务的任务中选择结束时间最短的,且判断与S集合中的任务是否相容
  3. 若不相容,则换下一个时间最短的任务,并进行比较
  4. 循环,直至X为空。

代码实现

# 任务规划
from collections import OrderedDict
task = OrderedDict()
task['r1'] = [0,4]
task['r2'] = [5,8]
task['r3'] = [10,13]
task['r4'] = [15,18]
task['r5'] = [7,11]
task['r6'] = [2,6]
task['r7'] = [2,6]
task['r8'] = [2,6]
task['r9'] = [12,16]
task['r10'] = [12,16]
task['r11'] = [12,16]
task['r12'] = [0,3]


listTask = list(task.items())
# 根据bi进行排序,结束时间早的在前面(冒泡排序)
for i in range(len(listTask)-1):
  for j in range(len(listTask)-i-1):
    if listTask[j][1][1] > listTask[j+1][1][1]:
      listTask[j],listTask[j+1]=listTask[j+1],listTask[j]
print(listTask)
out = []
out.append(listTask.pop(0))
def isValid(temp,out):
  for k in range(len(out)):
    if temp[1][0]<out[k][1][1]:
      # 相交
      return False
  return True

for j in range(len(listTask)):
  temp = listTask.pop(0)
  # 判断是否相交
  #   相交则continue
  #   不相交则out.append(temp)
  for k in range(len(out)):
    if isValid(temp,out):
      out.append(temp)
    # else:continue 语句可以不写
    else:
      continue
print(out)

以上就是python 贪心算法的实现的详细内容,更多关于python 贪心算法的资料请关注三水点靠木其它相关文章!

Python 相关文章推荐
Python 详解基本语法_函数_返回值
Jan 22 Python
python list排序的两种方法及实例讲解
Mar 20 Python
Python中is与==判断的区别
Mar 28 Python
为什么选择python编程语言入门黑客攻防 给你几个理由!
Feb 02 Python
python3.8 微信发送服务器监控报警消息代码实现
Nov 05 Python
在notepad++中实现直接运行python代码
Dec 18 Python
Django与pyecharts结合的实例代码
May 13 Python
Opencv图像处理:如何判断图片里某个颜色值占的比例
Jun 03 Python
在CentOS7下安装Python3教程解析
Jul 09 Python
Python判断字符串是否为合法标示符操作
Sep 03 Python
python实现图片素描效果
Sep 26 Python
python中pivot()函数基础知识点
Jan 03 Python
详解KMP算法以及python如何实现
Sep 18 #Python
python实现二分查找算法
Sep 18 #Python
Python自定义sorted排序实现方法详解
Sep 18 #Python
python爬虫爬取网页数据并解析数据
Sep 18 #Python
Python实现迪杰斯特拉算法过程解析
Sep 18 #Python
Python 操作 MySQL数据库
Sep 18 #Python
python实现人工蜂群算法
Sep 18 #Python
You might like
syphon 虹吸式咖啡冲泡冲煮倒水的得与失
2021/03/03 冲泡冲煮
PHP Directory 函数的详解
2013/03/07 PHP
php上传中文文件名乱码问题处理方案
2015/02/03 PHP
php实现httpRequest的方法
2015/03/13 PHP
Linux系统下php获得系统分区信息的方法
2015/03/30 PHP
Laravel事件监听器用法实例分析
2019/03/12 PHP
js克隆对象、数组的常用方法介绍
2013/09/26 Javascript
JS简单实现文件上传实例代码(无需插件)
2013/11/15 Javascript
js触发select onchange事件的小技巧
2014/08/05 Javascript
jquery实现无限分级横向导航菜单的方法
2015/03/12 Javascript
javascript实现炫酷的拖动分页
2015/05/11 Javascript
jQuery Mobile页面返回不需要重新get
2016/04/26 Javascript
vue打包的时候自动将px转成rem的操作方法
2018/06/20 Javascript
webpack4与babel配合使es6代码可运行于低版本浏览器的方法
2018/10/12 Javascript
ionic4+angular7+cordova上传图片功能的实例代码
2019/06/19 Javascript
浅谈Layui的eleTree树式选择器使用方法
2019/09/25 Javascript
微信小程序实现点击图片放大预览
2019/10/21 Javascript
JS apply用法总结和使用场景实例分析
2020/03/14 Javascript
vue 解决在微信内置浏览器中调用支付宝支付的情况
2020/11/09 Javascript
linux中如何使用python3获取ip地址
2019/07/15 Python
Python日期格式和字符串格式相互转换的方法
2020/02/18 Python
Django中的模型类设计及展示示例详解
2020/05/29 Python
Python中生成ndarray实例讲解
2021/02/22 Python
Python使用cn2an实现中文数字与阿拉伯数字的相互转换
2021/03/02 Python
anello泰国官方网站:日本流行包包品牌
2019/08/08 全球购物
韩国乐天网上商城:Lotte iMall
2021/02/03 全球购物
广州足迹信息技术有限公司Java软件工程师试题
2014/02/15 面试题
高中毕业自我鉴定
2013/12/13 职场文书
关于逃课的检讨书
2014/01/23 职场文书
秋季红领巾广播稿
2014/01/27 职场文书
学生会副主席竞聘书
2014/03/31 职场文书
酒店节能减排方案
2014/05/26 职场文书
党员个人批评与自我批评
2014/10/14 职场文书
德能勤绩廉个人总结
2015/02/14 职场文书
2015中秋节慰问信范文
2015/03/23 职场文书
创业计划书之都市休闲农庄
2019/12/28 职场文书