代码随想录算法训练营第三十一天|455.分发饼干、376.摆动序列、53.最大子数和

文档链接:https://programmercarl.com/

LeetCode455.分发饼干

题目链接:https://leetcode.cn/problems/assign-cookies/

思路:我采用的是优先用小饼干喂小孩。

贪心:

cpp 复制代码
class Solution {
public:
    int findContentChildren(vector<int>& g, vector<int>& s) {
        int count = 0;
        sort(g.begin(), g.end());
        sort(s.begin(), s.end());
        int i = 0;
        int j = 0;
        while(i < s.size() && j < g.size()) {
            if(s[i] >= g[j]) {
                count++;
                i++;
                j++;
            } else {
                i++;
            }
        }
        return count;
    }
};

LeetCode376.摆动序列

题目链接:https://leetcode.cn/problems/wiggle-subsequence/

思路:没太明白

贪心:

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

LeetCode53.最大子数和

题目链接:https://leetcode.cn/problems/maximum-subarray/

思路:遇到连续和为负数的情况就舍去,因为负数只会让后面加的数变小,但不是遇到负数就舍去,而是连续和。同时注意存一下每一次的最大值。

贪心:

cpp 复制代码
class Solution {
public:
    int maxSubArray(vector<int>& nums) {
        int result = INT_MIN;
        int sum = 0;
        for(int i = 0; i < nums.size(); i++) {
            sum += nums[i];
            if(sum > result) result = sum;
            if(sum < 0) sum = 0;
        }
        return result;
    }
};

总结:贪心真的好难,我原本以为的不就是每次取最优吗?不就是局部最优推出全局最优吗?结果拿到题目根本不知道什么是局部最优?什么是全局最优?

相关推荐
旭意2 分钟前
数据结构-红黑树和set
数据结构·c++·算法·蓝桥杯
宵时待雨2 分钟前
数据结构(初阶)笔记归纳7:链表OJ
c语言·开发语言·数据结构·笔记·算法·链表
充值修改昵称3 分钟前
数据结构基础:堆高效数据结构全面解析
数据结构·python·算法
2501_901147834 分钟前
组合总和IV——动态规划与高性能优化学习笔记
学习·算法·面试·职场和发展·性能优化·动态规划·求职招聘
人工智能培训6 分钟前
数字孪生技术:工程应用图景与效益评估
人工智能·python·算法·大模型应用工程师·大模型工程师证书
源代码•宸7 分钟前
Golang原理剖析(Go语言垃圾回收GC)
经验分享·后端·算法·面试·golang·stw·三色标记
mjhcsp20 分钟前
P14977 [USACO26JAN1] Lineup Queries S(题解)
数据结构·c++·算法
狐5723 分钟前
2026-01-22-牛客每日一题-二进制不同位数
算法·牛客
十八岁讨厌编程26 分钟前
【算法训练营 · 二刷总结篇】链表、哈希表部分
算法·链表·散列表
西瓜泡泡奶26 分钟前
代码随想录算法Day13|(二叉树part3)110.平衡二叉树、257. 二叉树的所有路径、404.左叶子之和、222.完全二叉树的节点个数
数据结构·算法·二叉树·平衡二叉树·完全二叉树·二叉树路径·左叶子之和