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

  • 今日学习的文章链接,或者视频链接

第八章 贪心算法 part01

  • 自己看到题目的第一想法

  • 看完代码随想录之后的想法

455:

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

376

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

53

动态规划:

cpp 复制代码
class Solution {
public:
    int maxSubArray(vector<int>& nums) {
        //以 nums[i] 为结尾的「最大子数组和」为 dp[i]
        int n = nums.size();
        if(n==0) return 0;
        vector<int> dp(n);
        dp[0] = nums[0];
        int result = dp[0];
        for(int i=1;i<n;i++){
            dp[i] = max(nums[i],dp[i-1]+nums[i]);
            result = max(result,dp[i]);
        }
        return result;

    }
};

贪心:

cpp 复制代码
class Solution {
public:
    int maxSubArray(vector<int>& nums) {
        int n = nums.size();
        if(n==0) return 0;
        int result = nums[0];
        int cur = 0;
        for (int i=0;i<n;i++){
            cur+=nums[i];
            if(cur>result){
                result = cur;
            }
            if(cur<0){
                cur = 0;
            }
        }
        return result;
    }
};
  • 自己实现过程中遇到哪些困难

  • 今日收获,记录一下自己的学习时长

相关推荐
bingbingyihao1 小时前
多数据源 Demo
java·springboot
tainshuai2 小时前
用 KNN 算法解锁分类的奥秘:从电影类型到鸢尾花开
算法·分类·数据挖掘
在努力的前端小白6 小时前
Spring Boot 敏感词过滤组件实现:基于DFA算法的高效敏感词检测与替换
java·数据库·spring boot·文本处理·敏感词过滤·dfa算法·组件开发
Coovally AI模型快速验证8 小时前
农田扫描提速37%!基于检测置信度的无人机“智能抽查”路径规划,Coovally一键加速模型落地
深度学习·算法·yolo·计算机视觉·transformer·无人机
pusue_the_sun8 小时前
数据结构:二叉树oj练习
c语言·数据结构·算法·二叉树
一叶飘零_sweeeet8 小时前
从繁琐到优雅:Java Lambda 表达式全解析与实战指南
java·lambda·java8
RaymondZhao348 小时前
【全面推导】策略梯度算法:公式、偏差方差与进化
人工智能·深度学习·算法·机器学习·chatgpt
艾伦~耶格尔9 小时前
【集合框架LinkedList底层添加元素机制】
java·开发语言·学习·面试
zhangfeng11339 小时前
DBSCAN算法详解和参数优化,基于密度的空间聚类算法,特别擅长处理不规则形状的聚类和噪声数据
算法·机器学习·聚类
一只叫煤球的猫9 小时前
🕰 一个案例带你彻底搞懂延迟双删
java·后端·面试