IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> Python数据结构18:找零问题的贪心算法代码,优化问题,解决优化问题的贪心策略 -> 正文阅读

[数据结构与算法]Python数据结构18:找零问题的贪心算法代码,优化问题,解决优化问题的贪心策略

1.优化问题

优化问题就是为了找到某些问题的最优解
最优:比如两个点之间有许多路径,找到最短的路径。
一个典型的优化问题:兑换最少硬币问题。就是当自动售货机找零的时候,每次找给顾客最少数量的硬币。
如果不是做最优解的话,就比较简单,就每次只找给1毛钱就行了。当然,很多人不能接受。

下面看一个实例:
假设你为一家自动售货机厂家编程序,自动售货
机要每次找给顾客最少数量硬币;假设某次顾客投进$1(1美元)纸币,买了?37(37美分)的东西,要找?63,那么最少数量就是:2个quarter(?25)、1个dime(?10)和3个penny(?1),一共6个硬币。

2.贪心策略Greedy Method

人们在解决上述的这些问题的时候,发现最直观的还是贪心策略。

从最大面值的硬币开始,用尽量多的数量。有余额的时候(例如用了2个25美分,还剩下13美分,不足以再用一个25美分),再到下一最大面值的硬币,还用尽量多的数量,一直到penny(?1,即最小的面额)为止。

贪心策略就是每次都试着解决问题的最大的一部分。
因为我们每次都试图解决问题的尽量大的一部分。对应到兑换硬币问题,就是每次以最多数量最大面值硬币来迅速减少找零面值。
在现实生活中,贪心策略确实是解决大多数硬币找零问题的有效方法。贪心策略是我们能想到的最直观有效的方法,反过来,也可以说,货币的面值就是按照贪心策略来设计的。

代码如下:

# 假设最大的面值是1美元,售货机的货物价格都低于1美元,可以找零的面值有25美分,10美分和1美分。
changes = [25, 10, 1]
input_money = 100  # 投入到售货机里面的是1美元,即100美分
print('Please enter the price of the item you selected:')
selection = int(input())
change = input_money - selection
count = 0  # count 用于计算硬币的个数
for i in changes:  # 从最大的面值依次向小面值找钱
    while change >= 0:  # 当要找的零钱数大于当前面值时
        change = change - i  # 计算找零后是否大于0,如果找零0大于0就代表还有可能继续用这个面值找钱,否则就要换下一个小面值了
        if change >= 0:  # 该面值找零后大于0,使用一个该面值的硬币
            count = count + 1
        else:  # 该面值找零后小于0,需要使用下一个面值的硬币,把需要找零的钱还原,跳出循环,进入下一个面值
            change = change + i
            break
print("The amount of change is %d" % count)

3. 贪心策略失效的情况

在一个漫画中,有一个杜撰的国家叫做(ELbonia),这个古怪的国家,除了有25美分,10美分和1美分以外,还有一种21美分?21的硬币。

在这个国家贪心策略就失效了,如果使用原来的贪心策略,
63 = 25 * 2 + 10 * 1 + 1 * 3 , 共 2 + 1 + 3 = 6枚硬币
但是最优的策略是,
63 = 21 * 3,共 3 枚硬币。
因此贪心策略严重依赖于货币的币值设计。

参考

本文的知识来源于B站视频 【慕课+课堂实录】数据结构与算法Python版-北京大学-陈斌-字幕校对-【完结!】,是对陈斌老师课程的复习总结
代码是我自己写的,功能比较简单

  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2022-09-25 23:20:35  更:2022-09-25 23:21:53 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/19 17:28:52-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码