力扣每日一题2024/03/30

本文介绍了一种解决给定整数数组和目标金额问题的算法,通过贪心策略确定需要添加到数组中以覆盖1到目标金额范围内所有整数所需的最小硬币数量。通过排序硬币面值并逐步构建可组合范围来实现这一目标。
摘要由CSDN通过智能技术生成

2952 需要添加的硬币的最小数量

给你一个下标从 0 开始的整数数组 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

思路

贪心来做。设可组合的数字范围为0-sum,初始时sum=0,需要满足的数字cur=0+1;开始遍历数组,若当前的数字coin[i]>cur,那么此时可组合的数字范围就为0-sum和coin[i]-sum+coin[i],中间断开的部分需要添加新的硬币面值来补充,且加入的面值越大越好,最大值为sum+1,此时可组合数字范围更新为0-sum+cur;若当前的数字coin[i]<=cur,加入该数字后不会出现区间断开的情况,只需要更新sum和cur,继续遍历。

代码

class Solution {
    public int minimumAddedCoins(int[] coins, int target) {
        int num=coins.length;
        int count=0;int sum=0;int x=1;
        Arrays.sort(coins);int i=0;
        while(x<=target){
            if(i<num&&coins[i]<=x){
                sum+=coins[i];x=sum+1;i++;
            }
            else {
                sum+=x;
                x=sum+1;count++;
            }
        }
        return count;
    }
}
  • 6
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值