LeetCode 2144. 打折购买糖果的最小开销(贪心)

文章目录

    • 1. 题目
    • 2. 解题

1. 题目

一家商店正在打折销售糖果。每购买 两个 糖果,商店会 免费 送一个糖果。

免费送的糖果唯一的限制是:它的价格需要小于等于购买的两个糖果价格的 较小值

比方说,总共有 4 个糖果,价格分别为 1 ,2 ,3 和 4 ,一位顾客买了价格为 2 和 3 的糖果,那么他可以免费获得价格为 1 的糖果,但不能获得价格为 4 的糖果。
给你一个下标从 0 开始的整数数组 cost ,其中 cost[i] 表示第 i 个糖果的价格,请你返回获得 所有 糖果的 最小 总开销。

示例 1:
输入:cost = [1,2,3]
输出:5
解释:我们购买价格为 23 的糖果,然后免费获得价格为 1 的糖果。
总开销为 2 + 3 = 5 。这是开销最小的 唯一 方案。
注意,我们不能购买价格为 13 的糖果,并免费获得价格为 2 的糖果。
这是因为免费糖果的价格必须小于等于购买的 2 个糖果价格的较小值。示例 2:
输入:cost = [6,5,7,9,2,2]
输出:23
解释:最小总开销购买糖果方案为:
- 购买价格为 97 的糖果
- 免费获得价格为 6 的糖果
- 购买价格为 52 的糖果
- 免费获得价格为 2 的最后一个糖果
因此,最小总开销为 9 + 7 + 5 + 2 = 23 。示例 3:
输入:cost = [5,5]
输出:10
解释:由于只有 2 个糖果,我们需要将它们都购买,而且没有免费糖果。
所以总最小开销为 5 + 5 = 10 。提示:
1 <= cost.length <= 100
1 <= cost[i] <= 100

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/minimum-cost-of-buying-candies-with-discount
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

2. 解题

  • 假设 a>b>c>da > b > c > da>b>c>da+b+d−(a+c+b)=d−c<0a+b+d-(a+c+b) = d-c < 0a+b+d(a+c+b)=dc<0,所有买最大的两个,免费获取第三大的,剩余的依次类推,是最优的方法
class Solution {
public:int minimumCost(vector<int>& cost) {// a > b > c > d// a+b+d-(a+c+b) < 0sort(cost.rbegin(), cost.rend());int ans = 0, n = cost.size();for(int i = 0; i < n; i+=3){ans += cost[i];if(i+1 < n)ans += cost[i+1];}return ans;}
};

8 ms 10.4 MB C++


我的CSDN博客地址 https://michael.blog.csdn.net/

长按或扫码关注我的公众号(Michael阿明),一起加油、一起学习进步!
Michael阿明

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/471273.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

在微型计算机中8m,第一部分 计算机基础知识部分习题(答案)

A)bit B)Byte C)bout D)baud95. 目前用于计算机的光盘有三大类&#xff1a;只读光盘、一次性写入光盘和_____C_____A)CD-ROM B)多媒体光盘C)可擦写光盘D)随机光盘96. 要将整屏幕打印出来应按___C_______.A)B)< Printscreen >C)< Printscreen > D)97. 与二进制数010…

淘宝弹性布局方案lib-flexible实践

2个月前&#xff0c;写过一篇文章《从网易与淘宝的font-size思考前端设计稿与工作流》总结过一些移动web中有关手机适配的一些思路&#xff0c;当时也是因为工作的关系分析了下网易跟淘宝的移动页面&#xff0c;最后才有那篇文章的总结&#xff0c;可惜的是因为项目的关系&…

jQuery学习笔记系列(二)

day02 - jQuery 学习目标&#xff1a; 能够操作 jQuery 属性 能够操作 jQuery 元素 能够操作 jQuery 元素尺寸、位置 1.1. jQuery 属性操作 ​ jQuery 常用属性操作有三种&#xff1a;prop() / attr() / data() ; 1.1.1 元素固有属性值 prop() ​ 所谓元素固有属性就是元素本…

LeetCode 2145. 统计隐藏数组数目(前缀和)

文章目录1. 题目2. 解题1. 题目 给你一个下标从 0 开始且长度为 n 的整数数组 differences &#xff0c;它表示一个长度为 n 1 的 隐藏 数组 相邻 元素之间的 差值 。 更正式的表述为&#xff1a;我们将隐藏数组记作 hidden &#xff0c;那么 differences[i] hidden[i 1] -…

飞思卡尔imx7 html5,i.MX6UL 飞思卡尔即将发布基于ARM Cortex-A7核心的低功耗处理器 i.MX 6UltraLite Processor...

i.MX6UL 飞思卡尔即将发布基于ARM Cortex-A7核心的低功耗处理器 i.MX 6UltraLite ProcessorFreescale飞思卡尔即将于7月份发布全新的基于ARM Cortex-A7核心的低功耗处理器i.MX6UL&#xff0c;主要面向车载信息处理、家庭能源管理系统、工控领域、物联网网关等应用。i.MX6UL是一…

简单table分页

html <table id"pagingTable"><thead><tr><td>第一列</td><td>第二列</td><td>第三列</td><td>第四列</td><td>第五列</td></tr></thead><tbody><tr><td…

logisim实验——通过2个半加器实现1-bit全加器,通过4个一位全加器构成4-bit加法器(详解)

一、由异或门和与门所构成的半加器&#xff1a; 二、由两个半加器构成的1-bit全加器&#xff1a; 注意&#xff1a;下图中所使用的四个1-bit全加器&#xff08;也就是正方形区域&#xff09;都是经过了封装的&#xff0c;所以外观与上图中的1-bit全加器有所区别&#…

LeetCode 2146. 价格范围内最高排名的 K 样物品(BFS)

文章目录1. 题目2. 解题1. 题目 给你一个下标从 0 开始的二维整数数组 grid &#xff0c;它的大小为 m x n &#xff0c;表示一个商店中物品的分布图。数组中的整数含义为&#xff1a; 0 表示无法穿越的一堵墙。1 表示可以自由通过的一个空格子。所有其他正整数表示该格子内的…

下列哪项属于正确的锁定计算机桌面,【2018年职称计算机考试WindowsXp练习题及答案1】- 环球网校...

【摘要】环球网校分享的“2018年职称计算机考试WindowsXp练习题及答案1”相关资料&#xff0c;供大家备考职称计算机考试有帮助&#xff0c;更多资料敬请关注环球职称计算机考试频道&#xff0c;网校会及时更新考试资讯……1.关闭窗口时有哪几种方式A 双击窗口标题栏最左侧的控…

CSS导入使用及引用的两种方法

方法一<link rel"stylesheet" type"text/css" href"test.css"> 方法二<style type"text/css">import url("http://localhost/demo.css");</style> 转载于:https://www.cnblogs.com/wuheng1991/p/5069880.…

一、操作系统——处理机(作业)调度算法:先来先服务算法FCFS、最短作业优先算法SJF(非抢占式)、 最短剩余时间优先算法SRTN(抢占式)、最高响应比优先算法HRRN

各种调度算法的学习思路&#xff1a; 调度算法的评价指标&#xff1a; 一、先来先服务算法&#xff08;FCFS&#xff09;&#xff1a;First Come First Serve 二、最短作业优先算法&#xff08;SJF非抢占式&#xff09;&#xff1a;Shortest Job First 三、最短剩余时间优先算法…

美国在理论计算机科学的研究重视,清华麻省理工香港中文联建理论计算机科学研究中心...

清华麻省理工香港中文联建理论计算机科学研究中心2010年06月25日 来源: 科学时报 浏览次数: 0本报讯 6月21日&#xff0c;清华大学—麻省理工学院—香港中文大学“理论计算机科学研究中心”在清华大学挂牌。该中心是MIT在中国成立的第一个联合中心&#xff0c;同时还是清华大学…

LeetCode 2147. 分隔长廊的方案数

文章目录1. 题目2. 解题1. 题目 在一个图书馆的长廊里&#xff0c;有一些座位和装饰植物排成一列。 给你一个下标从 0 开始&#xff0c;长度为 n 的字符串 corridor &#xff0c;它包含字母 ‘S’ 和 ‘P’ &#xff0c;其中每个 ‘S’ 表示一个座位&#xff0c;每个 ‘P’ 表…

二、操作系统——用信号量机制实现进程互斥、同步、前驱关系(详解)

一、什么是进程同步&#xff1f; 二、什么是进程互斥&#xff1f; 临界资源&#xff1a;一个时间段内只允许一个进程使用的资源 为了实现对临界资源的互斥访问&#xff0c;同时保证系统整体性能&#xff0c;需要遵循以下原则&#xff1a; 空闲让进。临界区空闲时&#xff…

firefox 插件 取消认证签名

Firebug Tab Mix plus :系统退出自动保存tab List。 tab mix options>Session>start/exit>when browse start>select "restore" option. zoom page 100%-downloadDownThemAll&#xff08;2016.5.26 record&#xff09; 未签名插件不能用了&#xff0c;比…

三、操作系统——生产者-消费者问题(两个同步一个互斥)

一、问题描述 信号量机制实现进程互斥的步骤&#xff1a; 设置初值为1的互斥信号量在访问临界区之间进行P操作在访问完临界区之后进行V操作 信号量机制实现进程同步的步骤&#xff1a; 设置初值为0的同步信号量在前操作之后对同步信号量执行V操作在后操作之前对同步信号量执…

计算机网络管理员中级第一套理论,计算机网络管理员第一套(中级)理论.doc

1、下列关于在知识产权制度中规定的“允许专利人对专利技术具有一定的垄断性并能够获得垄断”的理解&#xff0c;正确的是(D)A、违反了激励技术创新和保护技术创新的原则B、阻碍技术创新的不恰当做法C、不符合客观实际的做法D、激励技术创新和保护技术创新符合实际的正确做法--…

LeetCode 2148. 元素计数

文章目录1. 题目2. 解题1. 题目 给你一个整数数组 nums &#xff0c;统计并返回在 nums 中同时具有一个严格较小元素和一个严格较大元素的元素数目。 示例 1&#xff1a; 输入&#xff1a;nums [11,7,2,15] 输出&#xff1a;2 解释&#xff1a;元素 7 &#xff1a;严格较小元…

CSS浏览器兼容性----Hack

CSS Hack大致有3种表现形式&#xff0c;CSS类内部Hack、选择器Hack以及HTML头部引用(if IE)Hack&#xff0c;CSS Hack主要针对IE浏览器。类内部Hack&#xff1a;比如 IE6能识别下划线"_"和星号" * "&#xff0c;IE7能识别星号" * "&#xff0c;但…

四、操作系统——读者写者问题(详解)

一、问题描述&#xff1a; 二、需要满足的条件&#xff1a; 写进程与写进程之间必须互斥的写入数据&#xff08;因为如果两个写进程同时对共享数据中的区域A中的数据进行写操作的话&#xff0c;会导致数据错误覆盖的问题&#xff09;写进程与读进程之间必须互斥的访问共享数据…