贪心算法在找零问题中的应用

贪心算法在找零问题中的应用

  • 引言
  • a. 贪心算法求解找零问题
    • 算法设计
    • 算法证明
  • b. 硬币面额为c的幂时的贪心算法证明
    • 算法设计
    • 算法证明
  • c. 设计使贪心算法失效的硬币面额组合
  • d. 通用找零算法设计
    • 算法设计
    • 算法实现(伪代码)
    • 算法实现(C代码)
  • 结论

引言

找零问题是一个经典的优化问题,其目标是用最少的硬币找零给定的金额。贪心算法是解决这类问题的一种常用方法,其核心思想是在每一步选择中都采取最好或最优(即最有利)的选择,从而希望能够导致全局的最好或最优的解。在找零问题中,贪心算法的策略通常是根据硬币面额从大到小进行选择。

本文将围绕找零问题展开,通过贪心算法设计解决方案,并证明在特定条件下贪心算法的有效性。同时,也将探讨贪心算法失效的情况,并设计一种通用的找零算法。

在这里插入图片描述

a. 贪心算法求解找零问题

算法设计

假设我们有25美分、10美分、5美分和1美分四种面额的硬币。贪心算法的策略是尽可能多地使用面额较大的硬币,以减少硬币的总数。

  1. 初始化找零金额n
  2. 如果n大于等于25美分,则从n中减去25美分,并增加25美分硬币的数量。
  3. 如果n大于等于10美分且小于25美分,则从n中减去10美分,并增加10美分硬币的数量。
  4. 如果n大于等于5美分且小于10美分,则从n中减去5美分,并增加5美分硬币的数量。
  5. 如果n大于等于1美分且小于5美分,则从n中减去1美分,并增加1美分硬币的数量。
  6. 重复步骤2至5,直到n为0。

算法证明

要证明贪心算法在这种情况下能找到最优解,我们需要证明使用贪心策略找零所用的硬币数量是最少的。

假设存在一种更优的找零方式,它使用的硬币数量比贪心算法少。由于贪心算法总是优先使用面额较大的硬币,因此这种更优的方式必然在某个步骤中使用了比贪心算法更多的面额较小的硬币。然而,这会导致在后续步骤中可用的面额较大的硬币数量减少,从而需要更多的硬币来完成找零。这与假设更优的方式使用的硬币数量更少相矛盾。因此,贪心算法在这种情况下能找到最优解。

b. 硬币面额为c的幂时的贪心算法证明

算法设计

假设硬币面额是c的幂,即面额为C,c,…,C,c和k为整数,c>1,k≥1。在这种情况下,贪心算法依然优先使用面额较大的硬币。

算法证明

为了证明在这种情况下贪心算法总能得到最优解,我们可以使用数学归纳法。

基础情况:当k=1时,只有一种面额的硬币,贪心算法显然是最优的。

归纳假设:假设当k=m时,贪心算法是最优的。

归纳步骤:当k=m+1时,考虑使用贪心算法得到的找零方案。如果使用的最大面额的硬币数量为0,那么问题退化为k=m的情况,根据归纳假设,贪心算法是最优的。否则,如果我们使用至少一个最大面额的硬币,那么剩余的找零金额可以使用k=m的贪心算法来解决。由于归纳假设,这个子问题也是最优的。因此,当k=m+1时,贪心算法是最优的。

由数学归纳法,我们得出结论:当硬币面额为c的幂时,贪心算法总能得到最优解。

c. 设计使贪心算法失效的硬币面额组合

要使贪心算法不能保证得到最优解,我们需要设计一组特殊的硬币面额。一种常见的例子是使用1美分、3美分和4美分三种硬币。考虑找零7美分的情况,贪心算法会选择4美分和3美分,共需要两枚硬币。然而,最优解是使用两枚3美分硬币和一枚1美分硬币,共需要三枚硬币。因此,在这种情况下,贪心算法不能保证得到最优解。

d. 通用找零算法设计

算法设计

为了设计一个适用于任何k种不同面额硬币的通用找零算法,我们可以使用动态规划的方法。假设硬币面额为coins[k],找零金额为n

  1. 初始化一个大小为n+1的数组dp,其中dp[i]表示找零金额为i时所需的最少硬币数量。
  2. 对于每个金额i(从1到n),遍历所有硬币面额coins[j],如果coins[j]小于等于i,则更新dp[i]dp[i-coins[j]]+1dp[i]中的较小值。
  3. 返回dp[n]作为找零所需的最少硬币数量。

算法实现(伪代码)

function minCoins(coins, n):dp = array of size n+1 filled with ∞dp[0] = 0for i from 1 to n:for j from 0 to k-1:if coins[j] <= i:dp[i] = min(dp[i], dp[i-coins[j]] + 1)return dp[n]

算法实现(C代码)

#include <stdio.h>
#include <limits.h>int minCoins(int coins[], int k, int n) {int dp[n+1];for (int i = 0; i <= n; i++) {dp[i] = INT_MAX;}dp[0] = 0;for (int i = 1; i <= n; i++) {for (int j = 0; j < k; j++) {if (coins[j] <= i) {dp[i] = fmin(dp[i], dp[i-coins[j]] + 1);}}}return dp[n];
}int main() {int coins[] = {1, 3, 4};int k = sizeof(coins) / sizeof(coins[0]);int n = 7;printf("Minimum coins needed: %d\n", minCoins(coins, k, n));return 0;
}

结论

贪心算法在找零问题中是一种有效的策略,特别是在硬币面额为c的幂的情况下,它总能找到最优解。然而,当硬币面额不满足特定条件时,贪心算法可能会失效。为了处理更一般的情况,我们可以使用动态规划的方法设计一个通用的找零算法,该算法能够在任何硬币面额组合下找到最优解。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/4828.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

基于SpringBoot和PostGIS的各省与地级市空间距离分析

目录 前言 一、PostGIS时空库 1、时空表设计 2、空间数据管理与查询 二、后台接口设计 1、ORM层设计与实现 2、业务层设计与实现 3、控制层设计 三、web可视化设计与实现 1、省份范围展示 2、城市距离可视化 3、成果展示 总结 前言 在上一篇博客中基于Java和GDAL实…

充电桩选型对比:ESP32-S3模组和ESP32-C3模组谁更合适

随着新能源电车的普及&#xff0c;全国各地和海外都开始加紧安装充电桩&#xff0c;运城到2025年年底,实现充电桩城镇居住小区全覆盖&#xff0c;截至今年3月底,泉州市新增充电桩居民报装1.68万户。 启明云端是国内领先的物联网通讯产品和整体解决方案供应商&#xff0c;有非常…

Gromacs——教程学习(6)

谈谈怎么判断分子动力学模拟是否达到了平衡 在计算RMSD之前必须先通过最小二乘法将各帧结构相对于参考结构进行最大程度叠合&#xff0c;从而消除体系的整体运动而令RMSD只体现生物分子内部结构的变化&#xff0c;这称为align或者least squares fit。 需要注意的是&#xff0…

国产Sora诞生!清华团队发布Vidu大模型,可直接生成16秒视频

大模型之争已从单模态转向多模态。 4月27日&#xff0c;在2024中关村论坛年会未来人工智能先锋论坛上&#xff0c;清华大学联合北京生数科技有限公司正式发布了文生视频大模型——Vidu。 在会议上&#xff0c;清华大学人工智能研究院副院长、生数科技首席科学家朱军对外展示了…

stack,queue的模拟实现以及优先级队列

这篇博客用来记录stack&#xff0c;queue的学习。 stack的模拟实现 stack的模拟实现比较简单&#xff0c;先上代码 #pragma once #include<vector> #include<list> #include<deque> #include<iostream> using std::deque; using namespace std;name…

PyTorch中Torch.arange()函数详解

函数原型 arange(start0, end, step1, *, outNone, dtypeNone, layouttorch.strided, deviceNone, requires_gradFalse) -> Tensor 用法 返回大小为的一维张量&#xff0c;其值介于区间 为步长等间隔取值 参数说明 参数类型说明startNumber起始值&#xff0c;默认值&…

【Python的魅力】:利用Pygame实现游戏坦克大战——含完整源码

文章目录 一、游戏运行效果二、代码实现2.1 项目搭建2.2 加载我方坦克2.3 加载敌方坦克2.4 添加爆炸效果2.5 坦克大战之音效处理 三、完整代码 一、游戏运行效果 二、代码实现 坦克大战游戏 2.1 项目搭建 本游戏主要分为两个对象&#xff0c;分别是我方坦克和敌方坦克。用户可…

告别盲目投放,Xinstall让App广告效果一目了然

在移动互联网时代&#xff0c;App广告的投放已经成为企业营销的重要手段。然而&#xff0c;广告主在投放广告后&#xff0c;如何有效追踪广告效果、衡量广告ROI&#xff0c;一直是困扰他们的难题。今天&#xff0c;我们就来聊聊Xinstall这家国内专业的App全渠道统计服务商&…

计算一个结构的平方

在行列可自由变换的平面上计算3a1*3a1 得到的结构应该有9个点&#xff0c;并且点的分布有3a1的特征 这个9点结构可以化简成 1 1 1 1 1 1 1 1 1 显然这个结构可以再次平方&#xff0c;得到 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 …

python:reportlab 生成pdf:基本用法。

1.首先&#xff0c;打开cmd&#xff0c;安装reportlab pip install -i https://pypi.tuna.tsinghua.edu.cn/simple reportlab #从清华镜像安装更快 然后就可以使用其基本用法。 from reportlab.lib.pagesizes import letter from reportlab.pdfgen import canvasdef genera…

小程序评分/关键词/UV优化助力小程序登顶

随着小程序市场的日益繁荣&#xff0c;小程序搜索排名优化成为了众多开发者关注的焦点。小程序搜索排名被很多因素影响着&#xff0c;关键词、评分还有uv&#xff08;授权&#xff09;等。在本文小柚和各位老板分享如何有效优化小程序搜索排名的经验。 一、关键词策略 关键词是…

Python | Leetcode Python题解之第55题跳跃游戏

题目&#xff1a; 题解&#xff1a; class Solution:def canJump(self, nums: List[int]) -> bool:n, rightmost len(nums), 0for i in range(n):if i < rightmost:rightmost max(rightmost, i nums[i])if rightmost > n - 1:return Truereturn False

Web3的可持续性:构建环境友好的去中心化系统

引言 随着全球对可持续发展和环境问题的日益关注&#xff0c;Web3技术作为一种新型的互联网模式&#xff0c;也开始受到社区和开发者的关注。但很少有人关注到Web3对环境可持续性的潜在影响。本文将探讨Web3如何构建一个环境友好的去中心化系统&#xff0c;以及这如何促进一个…

偏微分方程算法之五点菱形差分法

目录 一、研究目标 二、理论推导 三、算例实现 四、结论 一、研究目标 上个专栏我们介绍了双曲型偏微分方程的主要算法及实现。从今天开始&#xff0c;我们在新的专栏介绍另一种形式偏微分方程-椭圆型的解法。 研究目标选取经典的二维椭圆型方程&#xff08;也称泊松Poisso…

马斯克突击访华;谷歌 Python 基础团队全数被裁;丨 RTE 开发者日报 Vol.195

开发者朋友们大家好&#xff1a; 这里是 「RTE 开发者日报」 &#xff0c;每天和大家一起看新闻、聊八卦。我们的社区编辑团队会整理分享 RTE&#xff08;Real Time Engagement&#xff09; 领域内「有话题的 新闻 」、「有态度的 观点 」、「有意思的 数据 」、「有思考的 文…

python基础学习之写入csv文件

前言 在Python编程中&#xff0c;经常会遇到要将数据存到csv文件中&#xff0c;今天来详细讲一下。 一.功能目的 将以下数据存到csv文件中。 data [ {name: Alice, age: 25, city: New York}, {name: Bob, age: 30, city: Los Angeles}, {name: Charlie, age: 35, city:…

DS:单链表的实现

欢迎各位来到 Harper.Lee 的编程学习小世界&#xff01; 博主主页传送门&#xff1a;Harper.Lee的博客 我将在这里分享我的学习过程等心得 创作不易&#xff0c;码字不易&#xff0c;兄弟们养成先赞后看的好习惯哦&#xff01; 想一同进步的uu&#xff0c;可以来后来找我哦&…

Selenium IDE 常见错误笔记

错误1&#xff1a;Failed:Exceeded waiting time for new window to appear 2000ms 这个错误通常出现在第一次运行时&#xff0c;有两个原因&#xff1a; Firefox阻止了弹出式窗口&#xff0c;在浏览器设置里允许这个操作即可。 有些网站设置了反扒机制&#xff0c;脚本运行…

解决Blender导出FBX文件到Unity坐标轴错误的问题

发现Blender的模型导入到Unity里面有问题,简单研究了下发现是坐标系不同,Unity使用的是左手坐标系,Blender使用的是右手坐标系 。 下面直接将如何解决 首先忽略Blender的右手坐标系以及Z轴朝上的事&#xff0c;依照unity坐标系情况修改模型物体的旋转&#xff0c;以Blender猴…

算法工程师——算法岗的分类及要求汇总

算法岗工程师 根据 Talent Seer 人才报告显示,全球 AI 从业者总人数约有 30 万,还是供不应求,其中 AI 技术专家(具有相关领域博士学位及 3 年以上工作经验的)约有 3.65 万。 简介 对于计算机专业的毕业生而言,算法岗基本上就是 「高薪」 的代名词。 在当今 IT 行业,算…