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

LeetCode 2706. 购买两块巧克力【数组,一次遍历】1207

本文属于「征服LeetCode」系列文章之一,这一系列正式开始于2021/08/12。由于LeetCode上部分题目有锁,本系列将至少持续到刷完所有无锁题之日为止;由于LeetCode还在不断地创建新题,本系列的终止日期可能是永远。在这一系列刷题文章中,我不仅会讲解多种解题思路及其优化,还会用多种编程语言实现题解,涉及到通用解法时更将归纳总结出相应的算法模板。

为了方便在PC上运行调试、分享代码文件,我还建立了相关的仓库:https://github.com/memcpy0/LeetCode-Conquest。在这一仓库中,你不仅可以看到LeetCode原题链接、题解代码、题解文章链接、同类题目归纳、通用解法总结等,还可以看到原题出现频率和相关企业等重要信息。如果有其他优选题解,还可以一同分享给他人。

由于本系列文章的内容随时可能发生更新变动,欢迎关注和收藏征服LeetCode系列文章目录一文以作备忘。

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

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

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

示例 1:

输入:prices = [1,2,2], money = 3
输出:0
解释:分别购买价格为 12 的巧克力。你剩下 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

解法 一次遍历

遍历 prices \textit{prices} prices ,维护最小值 mn 1 \textit{mn}_1 mn1 和次小值 mn 2 \textit{mn}_2 mn2

如果 mn 1 + mn 2 > money \textit{mn}_1+\textit{mn}_2>\textit{money} mn1+mn2>money ,那么剩余的钱会变成负数,返回 money \textit{money} money ,否则返回 money − mn 1 − mn 2 \textit{money}-\textit{mn}_1-\textit{mn}_2 moneymn1mn2

// python
class Solution:def buyChoco(self, prices: List[int], money: int) -> int:mn1 = mn2 = inffor p in prices:if p < mn1:mn2 = mn1mn1 = pelif p < mn2:mn2 = preturn money if mn1 + mn2 > money else money - mn1 - mn2// go
func buyChoco(prices []int, money int) int {mn1, mn2 := math.MaxInt, math.MinIntfor _, p := range prices {if p < mn1 {mn2 = mn1mn1 = p} else if p < mn2 {mn2 = p}}if mn1 + mn2 <= money {return money - mn1 - mn2}return money
}

复杂度分析:

  • 时间复杂度: O ( n ) \mathcal{O}(n) O(n) ,其中 n n n p r i c e s prices prices 的长度。
  • 空间复杂度: O ( 1 ) \mathcal{O}(1) O(1) 。仅用到若干额外变量。

相关文章:

  • P8780 [蓝桥杯 2022 省 B] 刷题统计
  • Java多线程之线程池,volatile,悲观锁,乐观锁,并发工具类
  • 机器学习之BP神经网络精讲(Backpropagation Neural Network(附案例代码))
  • 基于SpringBoot的在线互动学习网站
  • git上传代码到github远程仓库
  • 个人博客主题 vuepress-hope
  • ubuntu 如何放开防火墙端口,ubuntu 防火墙操作命令,ubuntu 防火墙全面操作说明
  • python读取xlsx格式的excel
  • Python面向对象-三大特性
  • MySQL基础笔记(1)基础理论
  • Python编程-面向对象基础与入门到实践一书的内容拓展
  • 【机电、机器人方向会议征稿|不限专业|见刊快】2024年机械、 图像与机器人国际会议(IACMIR 2024)
  • asp.net core webapi AutoMapper使用
  • 抖音详情API:从零开始构建抖音应用
  • Python教程(19)——python异常处理
  • 【许晓笛】 EOS 智能合约案例解析(3)
  • Angularjs之国际化
  • Invalidate和postInvalidate的区别
  • JavaScript的使用你知道几种?(上)
  • java中具有继承关系的类及其对象初始化顺序
  • Python进阶细节
  • Rancher-k8s加速安装文档
  • Shell编程
  • springboot_database项目介绍
  • Vue学习第二天
  • 创建一个Struts2项目maven 方式
  • 从PHP迁移至Golang - 基础篇
  • 搞机器学习要哪些技能
  • 基于MaxCompute打造轻盈的人人车移动端数据平台
  • 基于游标的分页接口实现
  • ------- 计算机网络基础
  • 面试题:给你个id,去拿到name,多叉树遍历
  • 前端面试之CSS3新特性
  • 浅谈Golang中select的用法
  • 浅谈Kotlin实战篇之自定义View图片圆角简单应用(一)
  • 区块链技术特点之去中心化特性
  • 使用iElevator.js模拟segmentfault的文章标题导航
  • 新手搭建网站的主要流程
  • 阿里云ACE认证学习知识点梳理
  • 机器人开始自主学习,是人类福祉,还是定时炸弹? ...
  • #Ubuntu(修改root信息)
  • #基础#使用Jupyter进行Notebook的转换 .ipynb文件导出为.md文件
  • (C语言版)链表(三)——实现双向链表创建、删除、插入、释放内存等简单操作...
  • (接口自动化)Python3操作MySQL数据库
  • (一)80c52学习之旅-起始篇
  • (原创) cocos2dx使用Curl连接网络(客户端)
  • (转)Android学习系列(31)--App自动化之使用Ant编译项目多渠道打包
  • (转)Scala的“=”符号简介
  • .bat批处理(五):遍历指定目录下资源文件并更新
  • .dat文件写入byte类型数组_用Python从Abaqus导出txt、dat数据
  • .NET CF命令行调试器MDbg入门(二) 设备模拟器
  • .NET Entity FrameWork 总结 ,在项目中用处个人感觉不大。适合初级用用,不涉及到与数据库通信。
  • .NET Windows:删除文件夹后立即判断,有可能依然存在
  • .Net面试题4
  • .NET下ASPX编程的几个小问题