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
相关推荐
Coovally AI模型快速验证16 分钟前
MMYOLO:打破单一模式限制,多模态目标检测的革命性突破!
人工智能·算法·yolo·目标检测·机器学习·计算机视觉·目标跟踪
可为测控1 小时前
图像处理基础(4):高斯滤波器详解
人工智能·算法·计算机视觉
Milk夜雨1 小时前
头歌实训作业 算法设计与分析-贪心算法(第3关:活动安排问题)
算法·贪心算法
ℳ₯㎕ddzོꦿ࿐1 小时前
解决Python 在 Flask 开发模式下定时任务启动两次的问题
开发语言·python·flask
CodeClimb1 小时前
【华为OD-E卷 - 第k个排列 100分(python、java、c++、js、c)】
java·javascript·c++·python·华为od
一水鉴天1 小时前
为AI聊天工具添加一个知识系统 之63 详细设计 之4:AI操作系统 之2 智能合约
开发语言·人工智能·python
BoBoo文睡不醒1 小时前
动态规划(DP)(细致讲解+例题分析)
算法·动态规划
Channing Lewis1 小时前
什么是 Flask 的蓝图(Blueprint)
后端·python·flask
B站计算机毕业设计超人2 小时前
计算机毕业设计hadoop+spark股票基金推荐系统 股票基金预测系统 股票基金可视化系统 股票基金数据分析 股票基金大数据 股票基金爬虫
大数据·hadoop·python·spark·课程设计·数据可视化·推荐算法
觅远2 小时前
python+playwright自动化测试(四):元素操作(键盘鼠标事件)、文件上传
python·自动化