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、从左向右,若 ratingsi​>ratingsi−1​,则第 i 名学生糖比第 i−1 名学生多 1 个。

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

python 复制代码
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:(第一位降序 -x0,第二位升序 x1 )`

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

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

python 复制代码
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

              
相关推荐
飞天狗1117 分钟前
零基础JavaWeb入门——第五课第一小节:九大内置对象 · 第1个:request(请求对象)
java·开发语言·前端·后端·servlet
z落落7 分钟前
C#ToolStrip+StatusStrip 状态栏实时显示系统时间+NotifyIcon系统托盘
开发语言·c#
插件开发18 分钟前
vs2015 cuda c++ 线程号的计算详解
开发语言·c++·算法
石山代码18 分钟前
变量与解构
开发语言·前端·javascript
有点。18 分钟前
C++(前缀和与差分)
c++·算法
c++之路23 分钟前
Bazel C++ 构建系列文档(五):多目标与多包项目
java·开发语言·c++
Hello:CodeWorld28 分钟前
【C++ 避坑指南】告别缓冲区溢出!全面解析 std::snprintf 的安全美学与核心陷阱
开发语言·c++·安全
凡人叶枫30 分钟前
Effective C++ 条款38:通过复合塑模出 has-a 或 \“根据某物实现出\
linux·开发语言·c++·windows
MemoriKu33 分钟前
Flutter 本地 AI 相册工程收口:从屏幕常亮、标签体系到照片属性后台队列
大数据·人工智能·python·flutter·elasticsearch·搜索引擎·数据库架构
枫叶丹434 分钟前
【HarmonyOS 6.0】MDM Kit:PC/2in1设备用户行为限制策略详解
开发语言·华为·harmonyos