力扣简单题 | 2706. 购买两块巧克力

题目

2706. 购买两块巧克力
给你一个整数数组 prices ,它表示一个商店里若干巧克力的价格。同时给你一个整数 money ,表示你一开始拥有的钱数。

你必须购买 恰好 两块巧克力,而且剩余的钱数必须是 非负数 。同时你想最小化购买两块巧克力的总花费。

请你返回在购买两块巧克力后,最多能剩下多少钱。如果购买任意两块巧克力都超过了你拥有的钱,请你返回 money 。注意剩余钱数必须是非负数。

示例 1:
输入:prices = [1,2,2], money = 3
输出:0
解释:分别购买价格为 1 和 2 的巧克力。你剩下 3 - 3 = 0 块钱。所以我们返回 0 。

示例 2:
输入:prices = [3,2,3], money = 3
输出:3
解释:购买任意 2 块巧克力都会超过你拥有的钱数,所以我们返回 3 。

提示:
2 <= prices.length <= 50
1 <= prices[i] <= 100
1 <= money <= 100

解题

这题比较简单,但还是遇到了几个问题:

  1. js要设置一个变量的初始值为理论上最大数字时要怎么做?用Number.MAX_VALUE或Infinity。Number.MAX_VALUE是JavaScript中能够表示的最大正数,而大于Number.MAX_VALUE的数字在JavaScript中将被表示为Infinity。
  2. 易错点:遇到比原来的最便宜巧克力还要便宜的巧克力时,应先把原来的最便宜赋值给第二便宜,再把新来的更便宜赋值给最便宜,而不是最便宜的值变了以后再赋值给第二便宜。
  3. a=1;b=2可以写作[a,b]=[1,2]
var buyChoco = function(prices, money) {
    let choco1 = Infinity;
    let choco2 = Infinity;
    prices.forEach(price => {
        if(price < choco1) {
            choco2 = choco1;
            choco1 = price;
        } else if(price === choco1) {
            choco2 = price;
        }
    })
    const restMoney = money - choco1 - choco2;
    return restMoney >= 0 ? restMoney : money;
};
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值