day31贪心算法part01| 理论基础 455.分发饼干 376. 摆动序列 53. 最大子序和

**455.分发饼干 **

视频讲解 | 力扣链接

刚开始想到的,但是这样太暴力了,太笨了

cpp 复制代码
class Solution {
public:
    int findContentChildren(vector<int>& g, vector<int>& s) {
        // 胃口g 饼干尺寸s
        int result = 0;
        sort(s.begin(), s.end());
        sort(g.begin(), g.end());
        vector<bool> usedg(g.size(), false);
        vector<bool> useds(s.size(), false);
        for (int i = s.size() - 1; i >= 0; i--) {
            for (int j = g.size() - 1; j >= 0; j--) {
                // cout << s[i] << " " << g[j] << endl;
                if (s[i] >= g[j] && usedg[j] == false && useds[i] == false) {
                    result++;
                    usedg[j] = true;
                    useds[i] = true;
                } 
            } 
        }
        cout << result;
        return result;
    }
};
cpp 复制代码
class Solution {
public:
    int findContentChildren(vector<int>& g, vector<int>& s) {
        // 孩子胃口g 饼干尺寸s
        sort(s.begin(), s.end());
        sort(g.begin(), g.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]) {
                result++;
                index--;
            }
        }
        return result;
    }
};

**376. 摆动序列 **

视频讲解 | 力扣链接

cpp 复制代码
class Solution {
public:
    int wiggleMaxLength(vector<int>& nums) {
        int result = 1;
        int prediff = 0, currdiff = 0; 
        for (int i = 0; i < nums.size() - 1; i++) {
            int currdiff = nums[i + 1] - nums[i];
            if ((currdiff < 0 && prediff >= 0) ||
                (currdiff > 0 && prediff <= 0)) {
                result++;
                prediff = currdiff;
            }
        }
        return result;
    }
};

ChatGPT给的另一个种方法

nums = [1, 7, 4, 9, 2, 5]

  • 起始时,数组的第一个元素(1)不需要比较。
  • 继续看第二个元素 (7),由于 7 > 1,说明有一个上升的摆动,所以 up 更新为 2。
  • 继续看第三个元素 (4),由于 4 < 7,说明有一个下降的摆动,所以 down 更新为 3。
  • 继续看第四个元素 (9),由于 9 > 4,说明又有一个上升的摆动,所以 up 更新为 4。
  • 继续看第五个元素 (2),由于 2 < 9,说明又有一个下降的摆动,所以 down 更新为 5。
  • 最后看第六个元素 (5),由于 5 > 2,说明又有一个上升的摆动,所以 up 更新为 6。

nums = [1,2,2,2,3,4]

  • 起始时,数组的第一个元素(1)不需要比较。
  • 继续看第二个元素 (2),由于 2 > 1,说明有一个上升的摆动,所以 up 更新为 2。
  • 继续看第三个元素 (2),由于 2 == 2,两个相等,没有变化,up 和 down 保持不变。
  • 继续看第四个元素 (2),由于 2 == 2,两个相等,没有变化,up 和 down 保持不变。
  • 继续看第五个元素 (3),由于 3 > 2,说明有一个上升的摆动,但由于之前的 up 已经是 2,up 保持不变。
  • 最后看第六个元素 (4),由于 4 > 3,说明有一个上升的摆动,但由于之前的 up 已经是 2,up 保持不变。

由于数组中的相等元素和连续的上升序列,不会影响最终的摆动序列的长度。贪心算法会自动跳过这些不影响摆动的元素,并只在检测到实际的上升或下降时更新 up 和 down 的值。

cpp 复制代码
class Solution {
public:
    int wiggleMaxLength(vector<int>& nums) {
        if (nums.size() <= 1) return nums.size();
        // 遍历数组并且仅在找到符合摆动条件的元素时更新子序列的长度。
        int up = 1, down = 1;
        for (int i = 1; i < nums.size(); i++) {
            if (nums[i] > nums[i - 1]) {
                up = down + 1;
            } else if (nums[i] < nums[i - 1]) {
                down = up + 1;
            }
        }
        
        return max(up, down);
    }
};

**53. 最大子序和 **

视频讲解 | 力扣链接

如果加和的过程中sum小于0了,那么立即从下一个数开始,因为sum为0了肯定得不到最大的连续和,负数只会拖累总和

cpp 复制代码
class Solution {
public:
    int maxSubArray(vector<int>& nums) {
        int result = INT32_MIN, sum = 0;
        for (int i = 0; i < nums.size(); i++) {
            sum += nums[i];
            result = sum > result ? sum : result;
            if (sum < 0) {
                sum = 0;
            }
        }
        return result;
    }
};
相关推荐
风筝在晴天搁浅4 分钟前
快手/字节 CodeTop LeetCode 415.字符串相加
算法·leetcode
DragonnAi30 分钟前
猫咪如厕检测与分类识别系统系列【十四】 项目结构重新整理-即将开源完整算法
算法·开源
机器视觉_Explorer1 小时前
【halcon】编程技巧:鼠标擦除
图像处理·人工智能·深度学习·算法·视觉检测
灵智实验室2 小时前
PX4状态估计技术EKF2详解(二):EKF2 误差状态动力学与协方差传播
算法·无人机·px 4
米粒12 小时前
力扣算法刷题 Day 64 Floyd算法 & A* 算法 & 总结篇
算法·leetcode·职场和发展
XX風2 小时前
OpenGL中Face culling 面剔除的具体实现
算法·图形渲染
IT猿手2 小时前
光伏模型参数估计:基于山羊优化算法(GOA )的光伏模型参数辨识问题求解研究,免费提供完整MATLAB代码链接
开发语言·算法·matlab·群智能优化算法·智能优化算法·光伏模型参数估计·光伏模型参数辨识
麻雀飞吧3 小时前
期货量化策略讲解:天勤量化下的跨期价差均值回归策略实战
python·算法·均值算法·回归
sali-tec3 小时前
C# 基于OpenCv的视觉工作流-章62-线线距离
图像处理·人工智能·opencv·算法·计算机视觉
WolfGang0073214 小时前
代码随想录算法训练营 Day53 | 图论 part11
算法·图论