【Day23 LeetCode】贪心算法题

一、贪心算法

贪心没有套路,只有碰运气(bushi),举反例看看是否可行,(运气好)刚好贪心策略的局部最优就是全局最优。

1、分发饼干 455

思路:按照孩子的胃口从小到大的顺序依次满足每个孩子,对于每个孩子,应该选择可以满足这个孩子的胃口且尺寸最小的饼干

CPP 复制代码
class Solution {
public:
    int findContentChildren(vector<int>& g, vector<int>& s) {
        sort(g.begin(), g.end());
        sort(s.begin(), s.end());
        int d1 = 0, d2 = 0;
        int cnt = 0;
        while(d2 < s.size() && d1 < g.size()){
            if(g[d1] <= s[d2++]){
                ++cnt;
                ++d1;
            }
        }
        return cnt;
    }
};

2、摆动序列 376

贪心:删除单调坡度上的节点,这个坡度就可以有两个局部峰值。所以求长度的问题变成求峰值个数。

CPP 复制代码
class Solution {
public:
    int wiggleMaxLength(vector<int>& nums) {
        int cur = 0, pre = 0;
        int ans = 1;
        for(int i=0; i<nums.size()-1; ++i){
            cur = nums[i+1] - nums[i]; // 当前的差值
            // 差值正负出现变化-->峰值出现
            if((cur > 0 && pre <= 0) || (cur < 0 && pre >= 0)){
                ++ans;
                pre = cur; // 只在摆动的时候更新
            }
        }
        return ans;
    }
};

3、最大子序和 53

思路:负的子序和只会拉低最大子序和

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

二、写在后面

贪心得多练。今天的摆动序列一开始没想出来。

相关推荐
青山木1 小时前
Hot 100 --- LRU 缓存
java·数据结构·算法·leetcode·链表·缓存·哈希
想你依然心痛2 小时前
AtomCode在算法竞赛中的实战体验:LeetCode周赛辅助编程
linux·算法·leetcode
剑挑星河月3 小时前
35.搜索插入位置
java·数据结构·算法·leetcode
闪电悠米3 小时前
力扣hot100-438.找到字符串中所有字母异位词-固定长度滑动窗口详解
linux·服务器·数据结构·算法·leetcode·滑动窗口·力扣hot100
小陈的代码之路16 小时前
回文链表(LeetCode 234)C语言最佳解题思路
c语言·leetcode·链表
郭梧悠19 小时前
算法:有效的括号
python·算法·leetcode
旖-旎19 小时前
《LeetCode 1137 第N个泰波那契数 和 LeetCode 三步问题》
c++·算法·leetcode·动态规划
wabs66619 小时前
关于动态规划【力扣718.最长重复子数组的思考】
算法·leetcode·动态规划
YuK.W21 小时前
Leetcode100: 94.二叉树中序遍历、104.二叉树最大深度、226.翻转二叉树
java·算法·leetcode·二叉树
想吃火锅10051 天前
【leetcode】146.LRU缓存js
算法·leetcode·缓存