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)
相关推荐
琹箐9 分钟前
最大堆和最小堆 实现思路
java·开发语言·算法
renhongxia139 分钟前
如何基于知识图谱进行故障原因、事故原因推理,需要用到哪些算法
人工智能·深度学习·算法·机器学习·自然语言处理·transformer·知识图谱
坚持就完事了39 分钟前
数据结构之树(Java实现)
java·算法
算法备案代理42 分钟前
大模型备案与算法备案,企业该如何选择?
人工智能·算法·大模型·算法备案
赛姐在努力.1 小时前
【拓扑排序】-- 算法原理讲解,及实现拓扑排序,附赠热门例题
java·算法·图论
野犬寒鸦2 小时前
从零起步学习并发编程 || 第六章:ReentrantLock与synchronized 的辨析及运用
java·服务器·数据库·后端·学习·算法
霖霖总总2 小时前
[小技巧66]当自增主键耗尽:MySQL 主键溢出问题深度解析与雪花算法替代方案
mysql·算法
rainbow68892 小时前
深入解析C++STL:map与set底层奥秘
java·数据结构·算法
wangjialelele3 小时前
平衡二叉搜索树:AVL树和红黑树
java·c语言·开发语言·数据结构·c++·算法·深度优先
驱动探索者3 小时前
linux mailbox 学习
linux·学习·算法