当前位置: 首页 > article >正文

Python3刷算法来呀,贪心系列题单

1.7号题单 

1、​​​​​​k次取反后最大值
2、柠檬水找零
3、分发糖果

  

示例 1:

输入:ratings = [1,0,2]
输出:5
解释:你可以分别给第一个、第二个、第三个孩子分发 2、1、2 颗糖果。

示例 2:

输入:ratings = [1,2,2]
输出:4
解释:你可以分别给第一个、第二个、第三个孩子分发 1、2、1 颗糖果。
     第三个孩子只得到 1 颗糖果,这满足题面中的两个条件。

 思路:1、每个人分到1颗糖果

2、从左向右,若 ratings[i​]>ratings[i−1​],则第 i 名学生糖比第 i−1 名学生多 1 个。

3、(再从右向左),如果 ratings[i] > ratings[i + 1],此时res[i](第i个小孩的糖果数量)就有两个选择了,一个是res[i + 1] + 1(从右边这个加1得到的糖果数量),一个是res[i](之前比较右孩子大于左孩子得到的糖果数量)。

class Solution:
    def candy(self, ratings: List[int]) -> int:
       n = len(ratings)
       num = [1]*n
       # 左到右
       for i in range(1,n):
        if ratings[i]>ratings[i-1]:
            num[i] = num[i-1]+1
       for i in range(n-2,-1,-1): #[n-2,-1) ,步长 -1
        if ratings[i]>ratings[i+1]:
            num[i] = max(num[i],num[i+1]+1)
       return sum(num)
        

4、根据升高重建队列

实例1:

输入:people = [[7,0],[4,4],[7,1],[5,0],[6,1],[5,2]]
输出:[[5,0],[7,0],[5,2],[6,1],[4,4],[7,1]]

示例 2:

输入:people = [[6,0],[5,0],[4,0],[3,2],[2,2],[1,4]]
输出:[[4,0],[5,0],[2,2],[3,2],[1,4],[6,0]]

 思路:1.先按高度h降序排,再按数量k升序排(停下来想想是不是),这里可以用lambda函数

`lambda x:(第一位降序 -x[0],第二位升序 x[1] )`

2.使用一个数组res,用于存入每次的数据;

3.核心:n表示新的res长度,第二位p[1]大于n,插入到res指定位置;小于等于直接append加入res

class Solution:
    def reconstructQueue(self, people: List[List[int]]) -> List[List[int]]:
        # p[h,k] 先h降序排,再k升序排;减少插入次数

        res = []
        people = sorted(people,key = lambda x:(-x[0],x[1] ))

        for p in people:
            if len(res) <= p[1]: #长度小于k
                res.append(p)
            elif len(res) > p[1]:
                res.insert(p[1],p)
        return res

              


http://www.kler.cn/a/472137.html

相关文章:

  • 【工具变量】统计行业锦标赛激励数据集(2008-2023年)
  • jenkins入门12-- 权限管理
  • 【阅读】认知觉醒
  • C++list
  • nlp培训重点-2
  • 【JavaWeb】2. 通用基础代码
  • 大数据-234 离线数仓 - 异构数据源 DataX 将数据 从 HDFS 到 MySQL
  • SQL编程语言
  • pytorch 比较两个张量的是否相等的函数介绍
  • Python爬虫应用领域
  • 计算机网络:虚拟机虚拟网络配置
  • 鸿蒙中黑白版
  • 基于RedHat9部署WordPress+WooCommerce架设购物网站
  • SQL Server存储过程来实现分页功能
  • TRELLIS - 生成 3D 作品的开源模型
  • KUKA机器人如何修改程序并下载到机器人控制器中?
  • uniapp uni-popup使用scroll-view滚动时,底部按钮设置position:fixed失效,部分ios设置有问题
  • 大模型RAG面试内容有哪些?(附面试资料合集)
  • redis学习-value数据结构
  • # Kafka组件化及拓展
  • Bash语言的数据类型
  • H5通过URL Scheme唤醒手机地图APP
  • 分享3个国内使用正版GPT的网站【亲测有效!2025最新】
  • CV-LLM经典论文解读|VTimeLLM: Empower LLM to Grasp Video MomentsVTimeLLM:赋能大语言模型理解视频片段
  • 使用react开发一个外卖程序
  • 【Pytorch报错】AttributeError: cannot assign module before Module.__init__() call