day31 贪心算法 分发饼干 摆动序列 最大子序和

题目1:455 分发饼干

题目链接:455 分发饼干

题意

给孩子分发饼干,每个孩子最多只能有1块饼干

每个孩子i都有一个胃口值g[i] ,每块饼干j的尺寸是s[j] 如果s[j]>=g[i]可以将这个饼干分配给孩子i 孩子就会得到满足,尽可能多地满足孩子,输出最大值

局部最优:将大尺寸的饼干分配给大胃口的孩子,充分利用饼干

全局最优:满足数量多的孩子

代码

cpp 复制代码
class Solution {
public:
    int findContentChildren(vector<int>& g, vector<int>& s) {
        //排序
        sort(g.begin(),g.end());
        sort(s.begin(),s.end());
        int result = 0;
        int index = s.size()-1;
        //先遍历胃口
        for(int i=g.size()-1;i>=0;i--){
            if(index>=0 && s[index]>=g[i]){
                index--;
                result++;
            }
        }
        return result;
    }
};
  • 时间复杂度:O(nlogn)
  • 空间复杂度:O(1)

题目2:376 摆动序列

题目链接:376 摆动序列

题意

连续数字之间的差在正数和负数之间交替,这样的数字序列称为摆动序列 仅由1个元素或两个不等元素的序列也是摆动序列

子序列可以从原始序列中删除或不删除元素获得,其余元素保持原始顺序不变

返回整数数组中摆动序列最长子序列的长度

局部最优:删除单调坡中的元素,全局最优:最长摆动序列

不用真正删除数组中的元素(O(n)),直接计数长度即可

默认数组有一个摆动序列的长度

代码

cpp 复制代码
class Solution {
public:
    int wiggleMaxLength(vector<int>& nums) {
        int result = 1;//计数序列的最右边
        int prediff = 0;
        int curdiff = 0;
        for(int i=0;i<nums.size()-1;i++){
            curdiff = nums[i+1] - nums[i];
            if((prediff>=0 && curdiff<0) || (prediff<=0 && curdiff>0)){
                result++;
                prediff = curdiff;
            }
        }
        return result;
    }
};
  • 时间复杂度:O(n)
  • 空间复杂度:O(1)

题目3:53 最大子序和

题目链接:53 最大子序和

题意

找出整数数组nums中具有最大和的连续子数组,返回最大和

连续和是负数,加上后面的数只会拖累后面的数,让后面的数更小,所以从后面的数重新计算连续和;只要连续和是正数,该连续和加上后面的数,就会增大后面的数

局部最优:连续和为负数,立刻抛去连续和,以下一个数为起点计算连续和

全局最优:找到最大连续和

贪心算法

代码

cpp 复制代码
class Solution {
public:
    int maxSubArray(vector<int>& nums) {
        int result = INT_MIN;
        int count = 0;
        for(int i=0;i<nums.size();i++){
            //计算连续和
            count += nums[i];
            if(count>result) result = count;
            if(count<0) count = 0;
        }
        return result;
    }
};
  • 时间复杂度:O(n)
  • 空间复杂度:O(1)
相关推荐
小肥柴7 分钟前
A2UI:面向 Agent 的声明式 UI 协议(三):相关概念和技术架构
算法
学高数就犯困3 小时前
性能优化:LRU缓存(清晰易懂带图解)
算法
CoovallyAIHub5 小时前
CVPR 2026 | MixerCSeg:仅2.05 GFLOPs刷新四大裂缝分割基准!解耦Mamba隐式注意力,CNN+Transformer+Mamba三
深度学习·算法·计算机视觉
CoovallyAIHub6 小时前
YOLO26-Pose 深度解读:端到端架构重新设计,姿态估计凭什么跨代领先?
深度学习·算法·计算机视觉
CoovallyAIHub6 小时前
化工厂气体泄漏怎么用AI检测?30张图3D重建气体泄漏场景——美国国家实验室NeRF新研究
深度学习·算法·计算机视觉
颜酱18 小时前
图的数据结构:从「多叉树」到存储与遍历
javascript·后端·算法
zone77391 天前
006:RAG 入门-面试官问你,RAG 为什么要切块?
后端·算法·面试
CoovallyAIHub1 天前
OpenClaw 近 2000 个 Skills,为什么没有一个好用的视觉检测工具?
深度学习·算法·计算机视觉
CoovallyAIHub1 天前
CVPR 2026 | 用一句话告诉 AI 分割什么——MedCLIPSeg 让医学图像分割不再需要海量标注
深度学习·算法·计算机视觉
CoovallyAIHub1 天前
Claude Code 突然变成了 66 个专家?这个 5.8k Star 的开源项目,让我重新理解了什么叫"会用 AI"
深度学习·算法·计算机视觉