[LeetCode周赛复盘] 第 100 场双周赛20230318
创始人
2025-05-30 21:40:54

[LeetCode周赛复盘] 第 100 场双周赛20230318

    • 一、本周周赛总结
    • 二、 [Easy] 6323. 将钱分给最多的儿童
      • 1. 题目描述
      • 2. 思路分析
      • 3. 代码实现
    • 三、[Medium] 6324. 最大化数组的伟大值
      • 1. 题目描述
      • 2. 思路分析
      • 3. 代码实现
    • 四、[Medium] 6351. 标记所有元素后数组的分数
      • 1. 题目描述
      • 2. 思路分析
      • 3. 代码实现
    • 五、[Hard] 6325. 修车的最少时间
      • 1. 题目描述
      • 2. 思路分析
      • 3. 代码实现
    • 六、参考链接

一、本周周赛总结

  • 补,这次双周赛比较简单,没打有点亏。
  • T1 分类讨论。
  • T2 双指针田忌赛马或者计数。
  • T3 排序模拟。
  • T4 二分。

二、 [Easy] 6323. 将钱分给最多的儿童

链接: 6323. 将钱分给最多的儿童

1. 题目描述

在这里插入图片描述

2. 思路分析

按题意模拟即可。

3. 代码实现

class Solution:def distMoney(self, money: int, children: int) -> int:if children == 1 and money == 4:return -1if money < children:return -1m = money - childrenans,mod = divmod(m,7)if ans == 0:return 0 if ans == children - 1:if mod == 3:return ans - 1return ans if ans == children:return ans - int(mod>0)if ans > children:return children - 1return ans 

三、[Medium] 6324. 最大化数组的伟大值

链接: 6324. 最大化数组的伟大值

1. 题目描述

在这里插入图片描述

2. 思路分析

  • 排序后最大化匹配,给尽可能多的数找一个比它大的数。
  • 双指针找就行。

  • 手玩一下发现,瓶颈在于最多的那个数,假设有c个,排序后只需要错位c个位置,就能保证剩下的都是符合要求的。
  • 假设排序后数组是112233344。发现有3个3
  • 令大的数组删去前边3个数,即左移3位。那么这个数组剩下的数都是满足>上边的数组。

3. 代码实现

、class Solution:def maximizeGreatness(self, nums: List[int]) -> int:# nums.sort(reverse=True)a = sorted(nums)n = len(a)l = 0ans = 0for v in a:if a[l] < v:ans += 1l += 1return ans

四、[Medium] 6351. 标记所有元素后数组的分数

链接: 6351. 标记所有元素后数组的分数

1. 题目描述

在这里插入图片描述

2. 思路分析

  • 直接带着下标排序,然后记录vis即可。
  • 我一定是疯了还用堆做。

3. 代码实现

class Solution:def findScore(self, nums: List[int]) -> int:marked = set()ans = 0for v,i in sorted([(v,i) for i,v in enumerate(nums)]):if i not in marked:ans += v marked.add(i-1)marked.add(i+1)return ans

五、[Hard] 6325. 修车的最少时间

链接: 6325. 修车的最少时间

1. 题目描述

在这里插入图片描述

2. 思路分析

  • 花的时间越多,越可能修完车。
  • 假设时间x能修完车,大于x的时间都能修完。
  • 假设时间y修不完,小于y的时间都修不完。
  • 因此有单调性,可以二分。
  • 实现时,发现值域很小,因此可以计数,单词扫描的时间可以降低。

3. 代码实现

class Solution:def repairCars(self, ranks: List[int], cars: int) -> int:cnt = Counter(ranks)s = lambda t: sum(floor((t // r) ** 0.5) * c for r, c in cnt.items())return bisect_left(range(min(cnt) * cars * cars), cars, key=s)      

六、参考链接

相关内容

热门资讯

玛雅人的五大预言 玛雅人预言2... 曾经玛雅人预言2012年是世界末日,但当时好像没有发生什么。没想到10年后的2022年,疫情,战争,...
cad打印线条粗细设置 cad... 004-线型(下)打印样式设置和线型文件使用一、线宽设置方法制图规范里边的线宽要求,我们已经定义好,...
应用未安装解决办法 平板应用未... ---IT小技术,每天Get一个小技能!一、前言描述苹果IPad2居然不能安装怎么办?与此IPad不...
荼蘼什么意思 岁月缱绻葳蕤生香... 感谢作者【辰夕】的原创独家授权分享编辑整理:【多肉植物百科】百科君坐标:云南 曲靖春而至,季节流转,...
长白山自助游攻略 吉林长白山游... 昨天介绍了西坡的景点详细请看链接:一个人的旅行,据说能看到长白山天池全凭运气,您的运气如何?今日介绍...