day27 代码随想录 | 贪心算法 分发饼干 摆动序列 最大子数组和

455 分发饼干

假设你是一位很棒的家长,想要给你的孩子们一些小饼干。但是,每个孩子最多只能给一块饼干。

对每个孩子 i,都有一个胃口值 g[i],这是能让孩子们满足胃口的饼干的最小尺寸;并且每块饼干 j,都有一个尺寸 s[j] 。如果 s[j] >= g[i],我们可以将这个饼干 j 分配给孩子 i ,这个孩子会得到满足。你的目标是尽可能满足越多数量的孩子,并输出这个最大数值。

这个题很自然而然的就是想 让大的去匹配大的,小的去匹配小的。我们将两个数组都排序

用胃口去比较饼干,可以从小到大去匹配,匹配到数组中止,就结束,记录就可以了

python 复制代码
class Solution:
    def findContentChildren(self, g: List[int], s: List[int]) -> int:
        g.sort()
        s.sort()
        i = 0
        j = 0
        while i < len(g) and j < len(s):
            if g[i] <= s[j]:
                i += 1
            j += 1
        
        return i

376 摆动序列

这个是真的难受

我们都知道摆动的条件,那就是三个数,如果两者的差异号,那说明就是正负交替

但是有一些细节

  1. 如果有重复元素呢,比如1,2,2,2,1。你的指针改怎么移动和判断呢,我们会得到1和2的差值是1 最后一个2和1的差值是-1,但是你指针应该怎么动,当我们遍历到i=1的时候, nums[i] - nums[i-1] = 1 那么后面 i+1-nums[i] = 0 你需要移动i,直到 最后i为最后,你需要保存你之前的那个1的差值,即pre_gap, 然后拿到你的cur_gap进行比较,但是在这之间,cur_gap是等于0的,你不能直接跳过重开,仍需要记录

  2. 初始化的问题。我们直到要保存 pre_gap , cur_gap ,初始应该为多少,总长度result应该为多少

pre_gap == cur_gap为0,result=1的,为什么? 假设是2,2,5,最终的result为2。具体可以看代码随想录。我觉得很简单的想法就是,初始化为1,就是序列最小就是为1

  1. 如何判断的问题?如何记录一个result, 当 cur_gap != 0 且pre_gap * cur*gap <=0的时候

result 要+1。 一个很特殊的情况是,如果你判断条件是<,那么对于3,3,5这种一开始pre_gap等于0 的,你用户不会有小于,你就GG了。因此,判断条件需要加上等于,但是还需要满足cur_gap不等于,为什么?就是为了排序排序这种3,3的在我们的序列中!

python 复制代码
class Solution:
    def wiggleMaxLength(self, nums: List[int]) -> int:
        if len(nums) == 1:
            return 1

        if len(nums) >= 2:
            pre_gap = nums[1] - nums[0]
            result =  2 if nums[1] != nums[0] else 1  # 这里我没有直接初始化,我是通过加判断
       
        for i in range(2, len(nums)):
            cur_gap = nums[i] - nums[i-1]
            if cur_gap * pre_gap <= 0 and cur_gap != 0 :
                result += 1
                pre_gap = cur_gap
        return result

53 最大子数组和

给你一个整数数组 nums ,请你找出一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和。

子数组是数组中的一个连续部分。

示例 1:

复制代码
输入:nums = [-2,1,-3,4,-1,2,1,-5,4]
输出:6
解释:连续子数组 [4,-1,2,1] 的和最大,为 6 。

这个题是在百度的面试题里面出现过。理解的核心点,对负数的处理。我们什么时候应该加负数,什么时候应该丢弃负数,重新开始子数列求和。这个题可以用贪心的思想去做,代码很简单,但是真的不好想。还有这个题目是连续的子数列! 你可以能想到我就用暴力解法,这没问题,大不了我双层循环,直接遍历求解,求最大。 对负数的处理我们肯定不是遇到负数就直接重新走一个新的子序列。那么我们应该怎么处理,我们处理的是累加和。也就是第i个元素和前i-1元素的累加和进行比较。如果num[i] + nums[i-1](这里的nums[i-1]已经是累加和了) > nums[i], 这说明,至少前面nums[i-1]是个整数,还可以加在一起;然后比较新的累加和与保存的最大累加和的大小,如果比保存的最大的累加和大,那就赋值新的最大累加和。

python 复制代码
class Solution:
    def maxSubArray(self, nums: List[int]) -> int:
        if len(nums) == 1:
            return nums[0]

        result = nums[0]
        
        for i in range(1, len(nums):
            if nums[i] + nums[i-1] > nums[i]:
                nums[i] = nums[i] + nums[i-1]
            if nums[i] > result:
                result = nums[i]

        return result
相关推荐
懒大王爱吃狼1 小时前
Python教程:python枚举类定义和使用
开发语言·前端·javascript·python·python基础·python编程·python书籍
劲夫学编程1 小时前
leetcode:杨辉三角
算法·leetcode·职场和发展
毕竟秋山澪1 小时前
孤岛的总面积(Dfs C#
算法·深度优先
秃头佛爷2 小时前
Python学习大纲总结及注意事项
开发语言·python·学习
浮生如梦_3 小时前
Halcon基于laws纹理特征的SVM分类
图像处理·人工智能·算法·支持向量机·计算机视觉·分类·视觉检测
深度学习lover3 小时前
<项目代码>YOLOv8 苹果腐烂识别<目标检测>
人工智能·python·yolo·目标检测·计算机视觉·苹果腐烂识别
API快乐传递者4 小时前
淘宝反爬虫机制的主要手段有哪些?
爬虫·python
励志成为嵌入式工程师5 小时前
c语言简单编程练习9
c语言·开发语言·算法·vim
师太,答应老衲吧5 小时前
SQL实战训练之,力扣:2020. 无流量的帐户数(递归)
数据库·sql·leetcode
捕鲸叉5 小时前
创建线程时传递参数给线程
开发语言·c++·算法