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分割文件的常用方法
Nov 01 Python
python通过定义一个类实例作为ftp回调方法
May 04 Python
深入解析Python编程中super关键字的用法
Jun 24 Python
Python字符编码判断方法分析
Jul 01 Python
基于Python_脚本CGI、特点、应用、开发环境(详解)
May 23 Python
分享一下Python数据分析常用的8款工具
Apr 29 Python
详解Django rest_framework实现RESTful API
May 24 Python
Sanic框架基于类的视图用法示例
Jul 18 Python
详解python数据结构和算法
Apr 18 Python
wxPython实现列表增删改查功能
Nov 19 Python
pytorch:实现简单的GAN示例(MNIST数据集)
Jan 10 Python
Python连接Oracle之环境配置、实例代码及报错解决方法详解
Feb 11 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
Search File Contents PHP 搜索目录文本内容的代码
2010/02/21 PHP
php代码中使用换行及(\n或\r\n和br)的应用
2013/02/02 PHP
php跨服务器访问方法小结
2015/05/12 PHP
php常用字符串长度函数strlen()与mb_strlen()用法实例分析
2019/06/25 PHP
javascript实现unicode和字符的互相转换
2007/07/18 Javascript
JavaScript CSS菜单功能 改进版
2008/12/20 Javascript
七个很有意思的PHP函数
2014/05/12 Javascript
简述AngularJS的控制器的使用
2015/06/16 Javascript
使用JavaScript脚本无法直接改变Asp.net中Checkbox控件的Enable属性的解决方法
2015/09/16 Javascript
JS+CSS相对定位实现的下拉菜单
2015/10/06 Javascript
js实现文字闪烁特效的方法
2015/12/17 Javascript
jQuery禁用键盘后退屏蔽F5刷新及禁用右键单击
2016/01/22 Javascript
JavaScript+html5 canvas实现图片破碎重组动画特效
2016/02/22 Javascript
浅谈几种常用的JS类定义方法
2016/06/08 Javascript
AngularJS 入门教程之HTML DOM实例详解
2016/07/28 Javascript
JS不完全国际化&amp;本地化手册 之 理论篇
2016/09/27 Javascript
细数JavaScript 一个等号,两个等号,三个等号的区别
2016/10/09 Javascript
浅谈在koa2中实现页面渲染的全局数据
2017/10/09 Javascript
js动态设置select下拉菜单的默认选中项实例
2018/08/21 Javascript
解决vscode进行vue格式化,会自动补分号和双引号的问题
2020/10/26 Javascript
[00:35]DOTA2上海特级锦标赛 EG战队宣传片
2016/03/04 DOTA
python的中异常处理机制
2018/08/30 Python
Django使用django-simple-captcha做验证码的实现示例
2021/01/07 Python
国际知名设计师时装商店:Coggles
2016/09/05 全球购物
法国一家芭蕾舞鞋公司:Repetto
2018/11/12 全球购物
英国地毯卖家:The Rug Seller
2019/07/18 全球购物
荷兰DOD药房中文官网:DeOnlineDrogist
2020/12/27 全球购物
自我评价是什么
2014/01/04 职场文书
楼面部长岗位职责范本
2014/02/14 职场文书
机械系毕业生求职信
2014/05/28 职场文书
如何签定毕业生就业协议书
2014/09/28 职场文书
代收款委托书范本
2014/10/01 职场文书
清洁员岗位职责
2015/02/15 职场文书
教师思想工作总结2015
2015/05/13 职场文书
2015年加油站站长工作总结
2015/05/27 职场文书
环保宣传语大全
2015/07/13 职场文书