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
相关推荐
Bruce_Liuxiaowei11 分钟前
使用Python脚本在Mac上彻底清除Chrome浏览历史:开发实战与隐私保护指南
chrome·python·macos
丶Darling.19 分钟前
26考研 | 王道 | 数据结构 | 第八章 排序
数据结构·考研·排序算法
ruyingcai66666623 分钟前
用python进行OCR识别
开发语言·python·ocr
Niuguangshuo26 分钟前
Python设计模式:MVC模式
python·设计模式·mvc
BB_CC_DD26 分钟前
四. 以Annoy算法建树的方式聚类清洗图像数据集,一次建树,无限次聚类搜索,提升聚类搜索效率。(附完整代码)
深度学习·算法·聚类
TOMGRIL30 分钟前
文件的读取操作
python
liuweidong080233 分钟前
【Pandas】pandas DataFrame radd
开发语言·python·pandas
IT_Octopus38 分钟前
AI工程pytorch小白TorchServe部署模型服务
人工智能·pytorch·python
CodeDevMaster1 小时前
browser-use:AI驱动的浏览器自动化工具使用指南
python·llm
我也不曾来过11 小时前
list底层原理
数据结构·c++·list