Python贪心算法实例小结


Posted in Python onApril 22, 2018

本文实例讲述了Python贪心算法。分享给大家供大家参考,具体如下:

1. 找零钱问题:假设只有 1 分、 2 分、五分、 1 角、二角、 五角、 1元的硬币。在超市结账 时,如果 需要找零钱, 收银员希望将最少的硬币数找给顾客。那么,给定 需要找的零钱数目,如何求得最少的硬币数呢?

# -*- coding:utf-8 -*-
def main():
  d = [0.01,0.02,0.05,0.1,0.2,0.5,1.0] # 存储每种硬币面值
  d_num = [] # 存储每种硬币的数量
  s = 0
  # 拥有的零钱总和
  temp = raw_input('请输入每种零钱的数量:')
  d_num0 = temp.split(" ")
  for i in range(0, len(d_num0)):
    d_num.append(int(d_num0[i]))
    s += d[i] * d_num[i] # 计算出收银员拥有多少钱
  sum = float(raw_input("请输入需要找的零钱:"))
  if sum > s:
    # 当输入的总金额比收银员的总金额多时,无法进行找零
    print("数据有错")
    return 0
  s = s - sum
  # 要想用的钱币数量最少,那么需要利用所有面值大的钱币,因此从数组的面值大的元素开始遍历
  i = 6
  while i >= 0: 
    if sum >= d[i]:
      n = int(sum / d[i])
      if n >= d_num[i]:
        n = d_num[i] # 更新n
      sum -= n * d[i] # 贪心的关键步骤,令sum动态的改变,
      print("用了%d个%f元硬币"%(n, d[i]))
    i -= 1
if __name__ == "__main__":
  main()

2. 求最大子数组之和问题:给定一个整数数组(数组元素有负有正),求其连续子数组之和的最大值。

# -*- coding:utf-8 -*-
def main():
  s = [12,-4,32,-36,12,6,-6]
  print("定义的数组为:",s)
  s_max, s_sum = 0, 0
  for i in range(len(s)):
    s_sum += s[i]
    if s_sum >= s_max:
      s_max = s_sum # 不断更新迭代s_max的值,尽可能的令其最大
    elif s_sum < 0:
      s_sum = 0
  print("最大子数组和为:",s_max)
if __name__ == "__main__":
  main()

3. 一辆汽车加满油后可行驶n公里。旅途中有若干个加油站。设计一个有效算法,指出应在哪些加油站停靠加油,使沿途加油次数最少。 对于给定的n(n <= 5000)和k(k <= 1000)个加油站位置,编程计算最少加油次数。

# 设汽车加满油后可行驶n公里,且旅途中有k个加油站
def greedy():
  n = 100
  k = 5
  d = [50,80,39,60,40,32]
  # 表示加油站之间的距离
  num = 0
  # 表示加油次数
  for i in range(k):
    if d[i] > n:
      print('no solution')
      # 如果距离中得到任何一个数值大于n 则无法计算
      return 
  i, s = 0, 0
  # 利用s进行迭代
  while i <= k:
    s += d[i]
    if s >= n:
      # 当局部和大于n时则局部和更新为当前距离
      s = d[i]
      # 贪心意在令每一次加满油之后跑尽可能多的距离
      num += 1
    i += 1
  print(num)
if __name__ == '__main__':
  greedy()

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

Python 相关文章推荐
python 正则式使用心得
May 07 Python
python中使用sys模板和logging模块获取行号和函数名的方法
Apr 15 Python
Python中的匿名函数使用简介
Apr 27 Python
hmac模块生成加入了密钥的消息摘要详解
Jan 11 Python
Python实现的FTP通信客户端与服务器端功能示例
Mar 28 Python
对Pandas DataFrame缺失值的查找与填充示例讲解
Nov 06 Python
详解python:time模块用法
Mar 25 Python
浅谈Pandas Series 和 Numpy array中的相同点
Jun 28 Python
python tkinter canvas使用实例
Nov 04 Python
keras 如何保存最佳的训练模型
May 25 Python
python音频处理的示例详解
Dec 23 Python
Python采集爬取京东商品信息和评论并存入MySQL
Apr 12 Python
python 判断网络连通的实现方法
Apr 22 #Python
Python3之读取连接过的网络并定位的方法
Apr 22 #Python
对Python 网络设备巡检脚本的实例讲解
Apr 22 #Python
python爬虫_实现校园网自动重连脚本的教程
Apr 22 #Python
selenium+python实现自动登录脚本
Apr 22 #Python
python实现校园网自动登录的示例讲解
Apr 22 #Python
用Python写一段用户登录的程序代码
Apr 22 #Python
You might like
apache rewrite_module模块使用教程
2008/01/10 PHP
PHP实现文件上传下载实例
2016/10/18 PHP
分享一个自定义的console类 让你不再纠结JS中的调试代码的兼容
2012/04/20 Javascript
JS实现金额转换(将输入的阿拉伯数字)转换成中文的实现代码
2013/09/30 Javascript
深入分析js的冒泡事件
2014/12/05 Javascript
jquery实现浮动的侧栏实例
2015/06/25 Javascript
基于JQuery实现仿网易邮箱全屏动感滚动插件fullPage
2015/09/20 Javascript
jQuery实现带遮罩层效果的blockUI弹出层示例【附demo源码下载】
2016/09/14 Javascript
基于Node的React图片上传组件实现实例代码
2017/05/10 Javascript
easyui简介_动力节点Java学院整理
2017/07/14 Javascript
JavaScript选取(picking)和反选(rejecting)对象的属性方法
2017/08/16 Javascript
JQuery EasyUI 结合ztrIee的后台页面开发实例
2017/09/01 jQuery
JavaScript实现简单生成随机颜色的方法
2017/09/21 Javascript
AngularJs 终极购物车(实例讲解)
2017/11/08 Javascript
8 个有用的JS技巧(推荐)
2019/07/03 Javascript
element-ui 本地化使用教程详解
2019/10/28 Javascript
easyUI 实现的后台分页与前台显示功能示例
2020/06/01 Javascript
Vue+Vant 图片上传加显示的案例
2020/11/03 Javascript
[02:57]DOTA2英雄基础教程 风行者
2014/01/16 DOTA
[58:15]2018DOTA2亚洲邀请赛 4.1 小组赛 A组 NB vs Liquid
2018/04/02 DOTA
web.py获取上传文件名的正确方法
2014/08/26 Python
轻松理解Python 中的 descriptor
2017/09/15 Python
在python中将字符串转为json对象并取值的方法
2018/12/31 Python
Python实现某论坛自动签到功能
2019/08/20 Python
Python新手学习标准库模块命名
2020/05/29 Python
结束运行python的方法
2020/06/16 Python
python 获取谷歌浏览器保存的密码
2021/01/06 Python
eBay法国购物网站:eBay.fr
2017/10/21 全球购物
意大利奢侈品购物网站:Giglio
2018/01/05 全球购物
彪马日本官网:PUMA日本
2019/01/31 全球购物
英国名牌服装购物网站:OD’s Designer
2019/09/02 全球购物
将时尚融入珠宝:Adornmonde
2019/10/17 全球购物
医药销售求职信范文
2014/02/01 职场文书
中学家长会邀请函
2014/02/03 职场文书
2014年统战工作总结
2014/12/09 职场文书
横空出世观后感
2015/06/09 职场文书