Leetcode1090. 受标签影响的最大值

思路:根据值从大到小排序,然后在加的时候判断是否达到标签上限即可,一开始想用字典做,但是题目说是集合却连续出现两个8,因此使用元组+SortedList进行解决

python 复制代码
class Solution:
    def largestValsFromLabels(self, values: list[int], labels: list[int], numWanted: int, useLimit: int) -> int:
        from sortedcontainers import SortedList
        from collections import defaultdict
        sorted_values = SortedList()
        for num in range(0, len(labels)):
            sorted_values.add((values[num], labels[num]))
        total_sum = 0
        label_dict = defaultdict(int)
        for value_label in reversed(sorted_values):
            value = value_label[0]
            label = value_label[1]
            if label_dict[label] < useLimit:
                if numWanted > 0:
                    numWanted -= 1
                    total_sum += value
                    label_dict[label] += 1
                else:
                    return total_sum
        return total_sum
相关推荐
xixihaha132439 分钟前
将Python Web应用部署到服务器(Docker + Nginx)
jvm·数据库·python
xixihaha13241 小时前
Python游戏中的碰撞检测实现
jvm·数据库·python
myloveasuka1 小时前
Java与C++多态访问成员变量/方法 对比
java·开发语言·c++
2301_821700531 小时前
C++编译期多态实现
开发语言·c++·算法
奥地利落榜美术生灬2 小时前
c++ 锁相关(mutex 等)
开发语言·c++
xixihaha13242 小时前
C++与FPGA协同设计
开发语言·c++·算法
重庆小透明2 小时前
【java基础篇】详解BigDecimal
java·开发语言
ID_180079054732 小时前
模拟1688商品详情的Python API实现,返回符合风格的JSON数据
开发语言·python·json
程序员小远2 小时前
软件测试之功能测试详解
自动化测试·软件测试·python·功能测试·测试工具·职场和发展·测试用例
小小怪7502 小时前
C++中的函数式编程
开发语言·c++·算法