力扣每日一题 6/13 反悔贪心算法

  • 博客主页:誓则盟约
  • 系列专栏:IT竞赛 专栏
  • 关注博主,后期持续更新系列文章
  • 如果有错误感谢请大家批评指出,及时修改
  • 感谢大家点赞👍收藏⭐评论✍ 

2813.子序列最大优雅度【困难

题目:

给你一个长度为 n 的二维整数数组 items 和一个整数 k 。

items[i] = [profiti, categoryi],其中 profiti 和 categoryi 分别表示第 i 个项目的利润和类别。

现定义 items 的 子序列 的 优雅度 可以用 total_profit + distinct_categories2 计算,其中 total_profit 是子序列中所有项目的利润总和,distinct_categories 是所选子序列所含的所有类别中不同类别的数量。

你的任务是从 items 所有长度为 k 的子序列中,找出 最大优雅度 。

用整数形式表示并返回 items 中所有长度恰好为 k 的子序列的最大优雅度。

注意:数组的子序列是经由原数组删除一些元素(可能不删除)而产生的新数组,且删除不改变其余元素相对顺序。

示例 1:

输入:items = [[3,2],[5,1],[10,1]], k = 2
输出:17
解释:
在这个例子中,我们需要选出长度为 2 的子序列。
其中一种方案是 items[0] = [3,2] 和 items[2] = [10,1] 。
子序列的总利润为 3 + 10 = 13 ,子序列包含 2 种不同类别 [2,1] 。
因此,优雅度为 13 + 22 = 17 ,可以证明 17 是可以获得的最大优雅度。 

示例 2:

输入:items = [[3,1],[3,1],[2,2],[5,3]], k = 3
输出:19
解释:
在这个例子中,我们需要选出长度为 3 的子序列。 
其中一种方案是 items[0] = [3,1] ,items[2] = [2,2] 和 items[3] = [5,3] 。
子序列的总利润为 3 + 2 + 5 = 10 ,子序列包含 3 种不同类别 [1, 2, 3] 。 
因此,优雅度为 10 + 32 = 19 ,可以证明 19 是可以获得的最大优雅度。

示例 3:

输入:items = [[1,1],[2,1],[3,1]], k = 3
输出:7
解释:
在这个例子中,我们需要选出长度为 3 的子序列。
我们需要选中所有项目。
子序列的总利润为 1 + 2 + 3 = 6,子序列包含 1 种不同类别 [1] 。
因此,最大优雅度为 6 + 12 = 7 。

提示:

  • 1 <= items.length == n <= 10**5
  • items[i].length == 2
  • items[i][0] == profiti
  • items[i][1] == categoryi
  • 1 <= profiti <= 10**9
  • 1 <= categoryi <= n
  • 1 <= k <= n

分析问题:

        解这道题主要还是要有一定的思维能力,对贪心算法有一定的知识储备。因为这道题考察的内容确实有点多,在它的标签里列出了 贪心,栈,数组,哈希表,排序,堆(优先队列);可见这题考的内容之丰富,不过不用慌,在Python中列表可以充当大部分的数据结构,把列表运用好可以解决大多数问题。

那么这道题的话思路如下:

先把items按照利润大小排序(假设从大到小排序),然后先取前k个,计算出当前的value值;

然后考虑k+1以及之后的元素,首先要明白k+1后面的元素的利润值都是低于之前的任何一个的,那么分类讨论:

  • 如果k+1的种类存在于前k个元素中,那么把k+1加进去没有任何意义,种类重复利润还少,直接跳过即可。
  • 如果k+1的种类不存在于前k个元素中,那么我们要选一个种类重复的且利润最小的元素出来和他交换,这时候利润虽然减小了但是种类+1了,记录此时的a_value值,于原value值相比,谁大取谁作为value。

        按照这个思路,往下遍历,计算优雅度,取最大值即可。 不过要注意的是这里要记录种类重复的元素,以及将他们按照利润大小排序。这里可以直接用一个列表和一个集合实现,因为遍历的顺序是按照利润从大到小,所以加入到ls里面的元素的顺序一定是按照利润值从大到小的,直接将其翻转,先拿小的交换,这里需要一个指针,交换一次指针向前走一步,标记要被交换的元素。接下来看具体的代码实现:


代码实现:

class Solution:def findMaximumElegance(self, items: List[List[int]], k: int) -> int:items.sort(key= lambda items:items[0],reverse=True)ls=items[:k] # 先按利益大小取前k个最大的元素seen,ll,su=set(),[],0 # seen用来标记出现过的种类for i,j in ls:if j not in seen: seen.add(j)else: ll.append([i,j])su+=ivalue=su+len(seen)**2  # 计算当前最大优雅度if len(ll)==0: return valuell,re=ll[::-1],0  # re 指针 用来标记要和ll中的哪个元素比较for q in items[k:]:if q[1] not in seen and re<=len(ll)-1:key=q[0]-ll[re][0]seen.add(q[1])su+=keyre+=1a_va=su+(len(seen))**2if a_va>value:value=a_vareturn value


总结:

代码逐行解释:

  1. 函数定义

    • 定义了名为 findMaximumElegance 的函数,接受 items 列表和整数 k 作为参数。
  2. 初始化操作

    • 对 items 按照第一项(利益大小)进行降序排序。
    • 取出前 k 个元素存储在 ls 列表中。
    • 创建空集合 seen 用于标记出现过的种类。
    • 创建空列表 ll 用于存储重复种类的元素。
    • 初始化变量 su 为 0,用于累计利益总和。
  3. 计算初始优雅度

    • 遍历 ls 中的每个元素 [i, j] ,如果 j 不在 seen 中,将其添加到 seen 中;否则,将该元素添加到 ll 中。
    • 累加 ls 中元素的利益到 su 。
    • 计算初始优雅度 value 为 su + len(seen) ** 2 。
  4. 处理剩余元素以优化优雅度

    • 如果 ll 不为空,将其反转。
    • 遍历 items 中 k 之后的元素 q 。
    • 如果 q 的种类不在 seen 中且 re 指针未超出 ll 的范围,计算用 q 替换 ll[re] 带来的利益变化 key 。
    • 更新 seen 、 su ,计算新的优雅度 a_va 。
    • 如果 a_va 大于当前的 value ,更新 value 。
  5. 返回结果

    • 函数最终返回计算得到的最大优雅度 value 。

 考查内容:

  1. 排序算法的应用:通过对 items 列表按照特定规则(第一项的利益大小)进行排序,为后续的选择操作奠定基础。
  2. 数据结构的运用:使用集合 seen 来快速判断元素的种类是否已经出现,利用列表 ll 存储重复种类的元素。
  3. 贪心算法的思想:先选择前 k 个利益最大的元素,然后通过逐步替换来尝试优化结果,体现了贪心选择局部最优以期望达到全局最优的思路。
  4. 逻辑推理和计算能力:在计算优雅度、判断是否替换元素以及更新相关变量时,需要准确的逻辑推理和计算。

学到的内容:

  1. 熟练掌握排序函数的使用,能够根据具体需求对数据进行排序。
  2. 学会运用合适的数据结构来提高算法的效率和便捷性,例如集合的快速查找和去重特性。
  3. 深入理解贪心算法的策略,以及如何在特定问题中应用贪心思想来解决优化问题。
  4. 提升了对复杂逻辑的分析和处理能力,包括条件判断、变量更新和结果优化。
  5. 培养了通过逐步推导和计算来求解最优解的思维方式,同时也学会了如何在算法中有效地管理和利用数据。

To sum up: 这道题的算法有另一个好听的名字叫 反悔贪心,难度还是在线的,多思考,多理解。 

“江流天地外,山色有无中。”——王维 

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

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

相关文章

上海2024年二手房最新成交历史数据

标签: 上海2024年二手房最新成交历史数据; 二手房; 时间: 2024年 上海市4月二手房网签套数:18230套 上海市5月二手房网签套数:19396套 上海市6月二手房网签套数: 6月1日:924套 6月2日:886套 6月3日:720套 6月4日:750套 6月5日:823套 6月6日:902套 6月7日:968套…

红黑树的基本概念

红黑树 特征 [1] 根节点是黑色的[2] 每个叶子节点都是黑色的空节点(NIL), 也就是说&#xff0c;叶子节点不存储数据[3] 任何相邻的节点都不能同时为红色&#xff0c;也就是说&#xff0c;红色节点是被黑色节点隔开的[4] 每个节点&#xff0c;从该节点到达其可达叶子节点的所有路…

阿里云香港服务器怎么样?

大家都知道阿里云是国内最受欢迎的云服务商&#xff0c;那么阿里云香港服务器究竟怎么样呢&#xff1f;和硅云的香港服务器用于做外贸网站等业务相比各有哪些优缺点呢&#xff1f; 阿里云和硅云在香港云服务领域有着广泛的应用和良好的口碑。然而&#xff0c;它们各自的特点和…

mysql如何存储ip地址

在MySQL中存储IP地址通常可以使用 VARCHAR 或 CHAR 类型来存储。IP地址在IPv4的情况下通常是点分十进制的形式&#xff0c;例如 192.168.1.1&#xff0c;可以用 VARCHAR(15) 来存储&#xff0c;因为IPv4最多15个字符&#xff08;包括点号&#xff09;。如果你需要支持IPv6地址&…

【V8引擎】 V8引擎如何运行JS的

文章目录 概要什么是V8引擎为什么需要V8引擎比较常见的javascript引起有哪些呢&#xff1f;V8引擎是如何工作的&#xff08;V8引擎的解析过程&#xff09;V8引擎的做了哪些优化 概要 本篇文章主要是讲V8引擎如何运行JS&#xff0c;对运行JS做了哪些优化 什么是V8引擎 V8 是一…

深入探究Java Character类:全面解析与应用实例

在Java编程中,Character类是一个用于操作单个字符的强大工具。作为Java标准库中的一部分,Character类封装了基本数据类型char,并提供了一系列方法来操作和检查字符属性,例如字母、数字、空白字符等。理解并熟练使用Character类对开发高效、可靠的Java应用程序至关重要。本文…

开发做前端好还是后端好?

目录 一、引言 二、两者的对比分析 技能要求和专业知识&#xff1a; 职责和工作内容&#xff1a; 项目类型和应用领域&#xff1a; 就业前景和市场需求&#xff1a; 三、技能转换和跨领域工作 评估当前技能&#xff1a; 确定目标领域&#xff1a; 掌握相关框架和库&a…

按键输入消抖

按键输入是人机对话不可缺少的一部分&#xff0c;对于消抖设计&#xff0c;一种是软件消抖&#xff0c;一种是硬件消抖。但在单片机电路设计中&#xff0c;采用电容消抖才是最佳的选择&#xff0c;其次才是定时器消抖。 1、按键输入采用软件消抖 1)、通过定时器方式定时读取按…

Vue3【二十一】Vue 路由模式(createWebHashHistory /createWebHistory )和RouterLink写法

Vue3【二十一】Vue 路由模式&#xff08;createWebHashHistory /createWebHistory &#xff09;和RouterLink写法 Vue3【二十一】Vue 路由模式和普通组件目录结构 createWebHistory history模式&#xff1a;url不带#号&#xff0c;需要后端做url适配 适合销售项目 利于seo crea…

【SCAU数据挖掘】数据挖掘期末总复习题库判断题及解析

1.离群点可以是合法的数据对象或者值。( ✓) 解析&#xff1a;离群点&#xff08;Outliers&#xff09;通常是与数据集中其他数据显著不同的数据点&#xff0c;但它们可以是合法的数据值。这些值可能是由于测量误差、数据录入错误、数据分布的自然属性等原因产生的。 3.关联规…

Spring框架的原理及应用详解(六)

本系列文章简介&#xff1a; 在当今的软件开发世界中&#xff0c;随着应用复杂性的不断增加和技术的快速发展&#xff0c;传统的编程方式已经难以满足快速迭代、高可扩展性和易于维护的需求。为此&#xff0c;开发者们一直在寻求更加高效、灵活且易于管理的开发框架&#xff0c…

[DDR4] DDR4 相对 DDR3差异与优势

依公知及经验整理,原创保护,禁止转载。 传送门: 总目录 1 差异总览 出处: https://www.kingston.com.cn/en/memory/ddr4-overview Description 描述DDR3DDR4Advantage 优势电压1.5V1.2V降低内存功耗需求容量512Mb-8Gb4Gb-16Gb更大的 DIMM 容量数据速率800Mb/s – 2133Mb/s1…

C#——结构和类问题总结

C#——结构和类问题总结 前言一、结构体是什么&#xff1f;1&#xff09;定义2&#xff09;特点 二、类&#xff08;对象&#xff09;是什么&#xff1f;1&#xff09;定义2&#xff09;特点 三、两者的差异性与选择环境&#xff1f;1&#xff09;差异性2&#xff09;选择环境 …

推荐一款WPF绘图插件OxyPlot

开始 使用 NuGet 包管理器添加对 OxyPlot 的引用(如果要使用预发布包,请参阅下面的详细信息)向用户界面添加PlotView在代码中创建一个PlotModel绑定到你的属性PlotModelModelPlotView例子 您可以在代码存储库的文件夹中找到示例。/Source/Examples NuGet 包 最新的预发布包由…

前端工程师不是软件工程师?

在当前的技术生态系统中&#xff0c;前端工程师与软件工程师这两个角色经常被混淆。尽管它们在某些方面有重叠&#xff0c;但实际上存在显著的差异。尤其是在前端工程师培训班出身的背景下&#xff0c;这种差异更为明显。本文将探讨为什么前端工程师不应被简单地归类为软件工程…

CyberDAO:引领Web3时代的DAO社区文化

致力于Web3研究和孵化 CyberDAO自成立以来&#xff0c;致力于推动Web3研究和孵化&#xff0c;吸引了来自技术、资本、商业、应用与流量等领域的上千名热忱成员。我们为社区提供多元的Web3产品和商业机会&#xff0c;触达行业核心&#xff0c;助力成员捕获Web3.0时代的红利。 目…

C语言---------深入理解指针

目录 一、字符指针 二、指针数组&#xff1a; 三、数组指针&#xff1a; 1、定义&#xff1a; 2、&数组名和数组名区别&#xff1a; 3、数组指针的使用&#xff1a; 四、数组参数&#xff0c;指针参数&#xff1a; 1、一维数组传参&#xff1a; 2、二维数组传参&am…

后端防接口被刷

1&#xff09;防火墙 防火墙也是互联网安全攻防中重要的屏障&#xff0c;我们通过配置访问规则&#xff0c;可以限制只有被允许的IP才可以进行访问。 防火墙还可以识别和阻止DDoS攻击&#xff0c;通过识别并过滤恶意流量请求&#xff0c;防火墙可以有效的防御&#xff0c;保护…

模拟电子技术基础(二)--PN结

PN结的本质 芯片都是由硅晶体制成&#xff0c;单个硅原子最外层有带有4个电子 在纯硅当中这些电子会两两形成共价键&#xff0c;此时周围形成非常稳定的八电子结构 在一个回路中&#xff0c;灯泡不亮&#xff0c;不导通&#xff0c;因为电池无法吸引其中的电子离开&#xff0c…

面向对象程序设计》第5章 多态(选择 判断 填空)

1-1 在类的定义中,前面有virtual关键字的成员函数就是虚函数。 T F | 参考答案 答案 T 2分 1-2 通过基类指针调用基类和派生类中的同名虚函数时,若该指针指向一个基类的对象,那么被调用的是基类的虚函数。 T F | 参考答案 答案 T 2分 1-3 通过基类指针调用…