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

需要添加的硬币的最小数量(Lc2952)——贪心+构造

给你一个下标从 开始的整数数组 coins,表示可用的硬币的面值,以及一个整数 target 。

如果存在某个 coins 的子序列总和为 x,那么整数 x 就是一个 可取得的金额 

返回需要添加到数组中的 任意面值 硬币的 最小数量 ,使范围 [1, target] 内的每个整数都属于 可取得的金额 。

数组的 子序列 是通过删除原始数组的一些(可能不删除)元素而形成的新的 非空 数组,删除过程不会改变剩余元素的相对位置。

示例 1:

输入:coins = [1,4,10], target = 19
输出:2
解释:需要添加面值为 2 和 8 的硬币各一枚,得到硬币数组 [1,2,4,8,10] 。
可以证明从 1 到 19 的所有整数都可由数组中的硬币组合得到,且需要添加到数组中的硬币数目最小为 2 。

示例 2:

输入:coins = [1,4,10,5,7,19], target = 19
输出:1
解释:只需要添加一枚面值为 2 的硬币,得到硬币数组 [1,2,4,5,7,10,19] 。
可以证明从 1 到 19 的所有整数都可由数组中的硬币组合得到,且需要添加到数组中的硬币数目最小为 1 。

示例 3:

输入:coins = [1,1,1], target = 20
输出:3
解释:
需要添加面值为 4 、8 和 16 的硬币各一枚,得到硬币数组 [1,1,1,4,8,16] 。 
可以证明从 1 到 20 的所有整数都可由数组中的硬币组合得到,且需要添加到数组中的硬币数目最小为 3 。

提示:

  • 1 <= target <= 105
  • 1 <= coins.length <= 105
  • 1 <= coins[i] <= target

问题简要描述:返回需要添加的硬币的最小数量 

细节阐述:

  1. s 表示已经构造出了 [0,...,s−1] 内的所有金额。如果 x≤s,那么我们可以将上面两个区间合并,得到 [0,s+x−1] 内的所有金额;如果 x>s,那么我们就需要添加一个面值为 s 的硬币,这样可以构造出 [0,2s−1] 内的所有金额,然后再考虑 x 和 s 的大小关系,其中x = coins[i]

Java 

class Solution {public int minimumAddedCoins(int[] coins, int target) {int ans = 0, s = 1;Arrays.sort(coins);for (int i = 0; s <= target; ) {if (i < coins.length && coins[i] <= s) {s += coins[i++];} else {ans++;s <<= 1;}}return ans;}
}

 Python3

class Solution:def minimumAddedCoins(self, coins: List[int], target: int) -> int:ans = i = 0s = 1coins.sort()while s <= target: if i < len(coins) and coins[i] <= s:s += coins[i]i += 1else:s <<= 1ans += 1return ans        

TypeScript

function minimumAddedCoins(coins: number[], target: number): number {coins.sort((a, b) => a - b);let ans = 0, s = 1;for (let i = 0; s <= target;) {if (i < coins.length && coins[i] <= s) {s += coins[i++];} else {ans++;s <<= 1;}}return ans;
};

http://www.lryc.cn/news/341119.html

相关文章:

  • 军工保密资质介绍及申请要求
  • ES6的编程风格
  • springboot 载入自定义的yml文件转DTO
  • webpack-(plugin,本地服务器,路径别名,安装vue)
  • http请求头导致了dial tcp:lookup xxxx on 10.43.0.10:53 no sunch host
  • 想要设计放大电路,必须掌握哪些?
  • 每天五分钟计算机视觉:基于卷积操作完成滑动窗口的图片分类?
  • UI设计/交互设计/视觉设计项目汇报/作品集Figma/PPT模板
  • 25、Lua 学习笔记之三(高阶话题)
  • 企业网盘搭建——LNMP
  • Go语言异常处理方式
  • 时序分析基本知识点
  • ELK(Elasticsearch+Logstash+Kibana)日志分析系统
  • 【投稿优惠-EI稳定检索】2024年地理信息技术与遥感测绘国际学术会议(ICGITRSM 2024)
  • MySQL的内外连接
  • Pandas连接MySQL数据库
  • 2024华中杯数学建模参考思路+完整代码+后续成品论文预约
  • ARM_day8:基于iic总线的通信
  • 33、Lua Cocos2d-x使用Luajit实现加密
  • spring 集成 mybatis
  • rtpengine 的端点学习模式
  • Windows 安装 A UDP/TCP Assistant 网络调试助手
  • web自动化系列-selenium的3种等待方式(十一)
  • 每日OJ题_完全背包④_力扣279. 完全平方数(一维和二维)
  • web项目中jsp页面不识别el表达式
  • 【Python基础】字典
  • 2024HW --> 安全产品 Powershell无文件落地攻击
  • 力扣哈哈哈哈
  • RUM 最佳实践-视觉稳定性的探索与实践
  • PostgreSQL的学习心得和知识总结(一百三十八)|深入理解PostgreSQL数据库之Protocol message构造和解析逻辑