news 2026/3/12 22:07:15

LeetCode 3075.幸福值最大化的选择方案:排序

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
LeetCode 3075.幸福值最大化的选择方案:排序

【LetMeFly】3075.幸福值最大化的选择方案:排序

力扣题目链接:https://leetcode.cn/problems/maximize-happiness-of-selected-children/

给你一个长度为n的数组happiness,以及一个正整数k

n个孩子站成一队,其中第i个孩子的幸福值happiness[i]。你计划组织k轮筛选从这n个孩子中选出k个孩子。

在每一轮选择一个孩子时,所有尚未被选中的孩子的幸福值将减少1。注意,幸福值不能变成负数,且只有在它是正数的情况下才会减少。

选择k个孩子,并使你选中的孩子幸福值之和最大,返回你能够得到的最大值

示例 1:

输入:happiness = [1,2,3], k = 2输出:4解释:按以下方式选择 2 个孩子: - 选择幸福值为 3 的孩子。剩余孩子的幸福值变为 [0,1] 。 - 选择幸福值为 1 的孩子。剩余孩子的幸福值变为 [0] 。注意幸福值不能小于 0 。 所选孩子的幸福值之和为 3 + 1 = 4 。

示例 2:

输入:happiness = [1,1,1,1], k = 2输出:1解释:按以下方式选择 2 个孩子: - 选择幸福值为 1 的任意一个孩子。剩余孩子的幸福值变为 [0,0,0] 。 - 选择幸福值为 0 的孩子。剩余孩子的幸福值变为 [0,0] 。 所选孩子的幸福值之和为 1 + 0 = 1 。

示例 3:

输入:happiness = [2,3,4,5], k = 1输出:5解释:按以下方式选择 1 个孩子: - 选择幸福值为 5 的孩子。剩余孩子的幸福值变为 [1,2,3] 。 所选孩子的幸福值之和为 5 。

提示:

  • 1 <= n == happiness.length <= 2 * 105
  • 1 <= happiness[i] <= 108
  • 1 <= k <= n

解题方法:排序

题目翻译:

每个孩子都有一个价值,一次只能压榨一个孩子的价值。每剥夺一个孩子的价值,其他娃子都会因为受到惊吓而价值减一,一旦某娃子没有了使用价值就会被立刻丢弃。

问最多压榨k个娃子最多夺取多少总价值。

怎么选?当然是按照价值大的优先选。没被压榨过的娃子们也会随着时间的流逝人老珠黄,但是没办法,一次只能压榨一个。

让娃子们俺价值从大到小排个序,每次压榨一个,第几次压榨被压榨孩子的价值就会减少几减1。

  • 时间复杂度O ( n log ⁡ n ) O(n\log n)O(nlogn)
  • 空间复杂度O ( log ⁡ n ) O(\log n)O(logn)

AC代码

C++
/* * @LastEditTime: 2025-12-25 12:59:03 */typedeflonglongll;classSolution{public:llmaximumHappinessSum(vector<int>&happiness,intk){sort(happiness.begin(),happiness.end(),greater<>());ll ans=0;for(inti=0;i<k;i++){ans+=max(0,happiness[i]-i);}returnans;}};
C++

当然,前娃都没价值的时候后娃子肯定也没价值了,可直接提前完工。

/* * @LastEditTime: 2025-12-25 13:00:12 */typedeflonglongll;classSolution{public:llmaximumHappinessSum(vector<int>&happiness,intk){sort(happiness.begin(),happiness.end(),greater<>());ll ans=0;for(inti=0;i<k;i++){happiness[i]-=i;if(happiness[i]<=0){returnans;}ans+=happiness[i];}returnans;}};
Python
''' LastEditTime: 2025-12-25 13:02:05 '''fromtypingimportListclassSolution:defmaximumHappinessSum(self,happiness:List[int],k:int)->int:returnsum(max(0,h-i)fori,hinenumerate(sorted(happiness,reverse=True)[:k]))
Java
/* * @LastEditTime: 2025-12-25 13:18:34 */importjava.util.Arrays;classSolution{publiclongmaximumHappinessSum(int[]happiness,intk){Arrays.sort(happiness);longans=0;intn=happiness.length;for(inti=0;i<k;i++){if(happiness[n-i-1]<=i){returnans;}ans+=happiness[n-i-1]-i;}returnans;}}
Go
/* * @LastEditTime: 2025-12-25 13:08:10 */packagemainimport"sort"funcmaximumHappinessSum(happiness[]int,kint)(ansint64){sort.Slice(happiness,func(i,jint)bool{returnhappiness[i]>happiness[j]})fori:=0;i<k;i++{happiness[i]-=iifhappiness[i]<=0{return}ans+=int64(happiness[i])}return}
Rust
/* * @LastEditTime: 2025-12-25 13:12:12 */implSolution{pubfnmaximum_happiness_sum(muthappiness:Vec<i32>,k:i32)->i64{letmutans:i64=0;happiness.sort_by(|a:&i32,b:&i32|b.cmp(a));foriin0..k{ifhappiness[iasusize]<=i{returnans;}ans+=(happiness[iasusize]-i)asi64;}ans}}

同步发文于CSDN和我的个人博客,原创不易,转载经作者同意后请附上原文链接哦~

千篇源码题解已开源

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/10 19:35:31

15、Windows Azure 存储服务入门与 REST API 详解

Windows Azure 存储服务入门与 REST API 详解 1. Windows Azure 存储服务概述 在 Windows Azure 中,有多种存储服务可供选择,不同的服务有不同的特点和适用场景。 1.1 表存储(Table Storage) 应用开发者可以使用分区键精确控制数据的物理分区。选择合适的分区键至关重要…

作者头像 李华
网站建设 2026/3/9 3:12:11

17、探索Windows Azure存储:从基础到应用

探索Windows Azure存储:从基础到应用 1. 构建存储客户端的挑战与实现 在为新的语言或平台实现存储客户端库时,可能会遇到一些难题。部分主流语言不支持SHA - 256(不过HMAC部分实现起来较为简单)。例如,若要实现该库的Erlang版本,就需要自行研究SHA - 256和HMAC的实现(…

作者头像 李华
网站建设 2026/3/11 10:56:42

20、高速网络中的缓冲区管理策略解析

高速网络中的缓冲区管理策略解析 1. 缓冲区管理概述 缓冲区管理是一种决定何时以及如何丢弃数据包以避免网络拥塞的策略。其性能可通过在拥塞期间公平且高效地控制流量的能力来衡量。通常,数据包丢弃决策要么在新数据包到达时做出,要么在拥塞开始时做出,此时可能会丢弃当前…

作者头像 李华
网站建设 2026/3/11 10:56:27

21、ATM网络与互联网缓冲管理技术解析

ATM网络与互联网缓冲管理技术解析 1. ATM网络的信元处理 在ATM网络中,对于相同损失优先级(LP)的服务类别,信元丢失率存在一定情况。虽然可以分别精确计算这些服务类别的信元丢失率,但这会增加实现复杂度。由于差异较小,为简化实现,可将I类和III类的信元丢失情况合并,…

作者头像 李华
网站建设 2026/3/13 2:35:31

22、网络缓冲区管理机制深度解析

网络缓冲区管理机制深度解析 在网络通信中,缓冲区管理是确保网络高效、稳定运行的关键环节。不同的缓冲区管理机制各有特点,适用于不同的网络场景。下面将详细介绍几种常见的缓冲区管理机制。 1. RED与尾丢弃路由器对比 尾丢弃(Tail Drop)路由器在处理TCP连接时存在一些…

作者头像 李华
网站建设 2026/3/13 4:00:40

26、TCP/IP网络中的性能参数与拥塞控制策略解析

TCP/IP网络中的性能参数与拥塞控制策略解析 1. RTT估计的重要性及算法 在TCP交换中,往返时间(RTT)估计是最重要的性能参数之一,尤其是在考虑吞吐量时。如果RTT估计过低,数据包会被不必要地重传;如果过高,主机在等待超时时连接会处于空闲状态。不同的网络环境对RTT的要…

作者头像 李华