当前位置: 首页 > news >正文

oppo开发者选项在哪seo服务外包价格

oppo开发者选项在哪,seo服务外包价格,官方网站管理办法,太原云建站模板原题链接 文章目录 需要添加的硬币的最小数量:贪心算法实现题目概述示例分析 关键思路分析贪心算法的优化选择证明案例推演与算法实现 C 实现结论 需要添加的硬币的最小数量:贪心算法实现 题目概述 在这个困难难度的算法题中,我们要解决的…

原题链接

文章目录

  • 需要添加的硬币的最小数量:贪心算法实现
    • 题目概述
      • 示例分析
    • 关键思路分析
      • 贪心算法的优化选择证明
      • 案例推演与算法实现
    • C++ 实现
    • 结论

需要添加的硬币的最小数量:贪心算法实现

题目概述

在这个困难难度的算法题中,我们要解决的问题是确定在给定一系列硬币面值的情况下,为了使[1, target]区间内的每个整数都可以由这些硬币的某种组合表示出来,需要向数组中添加的最小数量的硬币。

示例分析

  • 示例 1:
    • 输入: coins = [1,4,10], target = 19
    • 输出: 2 (需要添加面值2和8的硬币)
  • 示例 2:
    • 输入: coins = [1,4,10,5,7,19], target = 19
    • 输出: 1 (仅需要添加面值为2的硬币)
  • 示例 3:
    • 输入: coins = [1,1,1], target = 20
    • 输出: 3 (需要添加面值为4、8和16的硬币)

关键思路分析

解决问题的关键在于贪心算法的应用。核心思想是对于每个无法直接凑出的金额x,添加面值为x的硬币以达到最优效果。通过这种方法,我们可以逐步构建出一个能够覆盖[1, target]区间的硬币集合。

贪心算法的优化选择证明

我们可以根据这个案例抽象出普遍性做法。如果要靠添加硬币的方式,才能凑出金额x,如果此时已经能凑出[1, s]的金额(x = s + 1),我们应该选择添加面值x,以得到更优结果。

证明:

选择1. 如果添加小于x的面值:
比如说添加面值small,此时面值small与金额x - small也可以凑出金额x。增加了面值small后,[small + 1, small + 2, small + 3…small + s]这些金额都可以通过与前面的金额相加凑出,不妨想象一个区间[small + 1, small + s],因为x - small是位于[1, s]之中的(x = s + 1,且small至少为1,因此x - small至少为x - 1 = s),所以现在可以凑出x了,还可以凑出[x, small + s]中的金额,结合原来的[1, s],我们可以凑出[1, small + s]的金额。

选择2. 添加面值x:
增加了面值x后,[x + 1, x + 2, x + 3…x + s]这些金额都可以通过与前面的金额相加凑出,因此可以结合前面的区间凑出[1, x + s]

选择3. 添加大于x的面值:
如果添加面值x + 1,原先能凑出的区间为[1, s],因为x = s + 1,x + 1 = s + 2,此时依然无法凑出金额x,因为区间没有覆盖到x这个点上,因此这个方案无效

综合以上3个选择,我们可以比对[1, small + s]和[1, x + s],因为small < x,所以毫无疑问选择x是最优做法。

案例推演与算法实现

[案例推演与算法实现的内容保持不变]

C++ 实现

实现中,首先对硬币进行排序,然后遍历每个硬币,同时维护一个变量x表示当前考虑的金额,以及一个变量s表示目前可以凑出的最大金额。若当前硬币面值大于x,则添加面值为x的硬币,直到可以凑出当前考虑的硬币面值为止。这个过程一直重复,直到可以凑出目标金额target

class Solution {
public:int minimumAddedCoins(vector<int>& coins, int target) {sort(coins.begin(), coins.end());long long ans = 0, s = 0, x = 1;for (auto c : coins) {if (c > x) {while (c > x) {s = s + x;x = s + 1;ans++;}}s = s + c;x = s + 1;}while (s < target) {s = s + x;x = s + 1;ans++;     }return ans;}
};

结论

通过贪心算法的应用,我们可以有效地解决这个算法问题,确保在给定硬币面值的情况下,以最小的硬币数量覆盖[1, target]的所有整数。

http://www.tj-hxxt.cn/news/86140.html

相关文章:

  • 购物网页设计总结奶盘seo伪原创工具
  • 国外网站怎么做沈阳百度seo关键词排名优化软件
  • 做网站需要做需求分析吗西部数码域名注册
  • 做网站需要的东西推广普通话手抄报简单又好看
  • 亚马逊联盟wordpress主题优化设计的答案
  • 福州成人报考网站长沙网站建设公司
  • 网站开发记什么费用引流推广网站
  • 网站制作的公司域名注册查询入口
  • 海外 酒店 网站建设世界杯比分
  • 总工会网站建设方案舆情信息
  • 爱站网官网关键词查询手机端百度收录入口
  • 沂水网站制作百度竞价优缺点
  • 北京公司注册核名详细流程天津seo优化公司哪家好
  • 大网站有哪些小说推广关键词怎么弄
  • 网站地图后台可以做吗站长统计app软件下载官网
  • 为什么资讯网站荣誉被收录长沙网站优化排名推广
  • 网站建设创意广告词快速排名上
  • 计算机软件开发就业前景镇江关键字优化公司
  • 门户网站应该怎么做dw友情链接怎么设置
  • wordpress 正文 宽度江西网络推广seo
  • 造价师在哪个网站做继续教育拓客软件
  • 在线网站建设活动产品推广软文范文
  • erp网站建设org域名注册
  • php是网站开发的语言吗软文代写接单平台
  • 集团网站建设公司乔拓云网站注册
  • 怎样做模板网站如何做好网络营销管理
  • 河北网站建设公司排名免费行情网站app大全
  • 深圳营销网站制作免费行情软件网站下载
  • 峰峰企业做网站推广站长之家论坛
  • 鹰潭网站建设yt1983广告代运营公司