代码随想录刷题|贪心算法理论 LeetCode455.分发饼干 376. 摆动序列 53. 最大子序和

简介: 代码随想录刷题|贪心算法理论 LeetCode455.分发饼干 376. 摆动序列 53. 最大子序和

贪心算法理论


  • 贪心算法分阶段工作
  • 在每一个阶段,可以认为所作决定是好的,而不考虑将来的后果
  • 这意味着选择的是某个局部最优,这种“眼下能够拿到的就拿”的策略是这类算法的名称的来源
  • 当算法终止的时候,我们希望局部最优等于全局最优。如果是这样的话,那么算法就算正确
  • 贪心算法没有什么套路


455.分发饼干

题目链接:力扣

思路


这里有两种思路:


       1、优先考虑胃口:从大到小一次遍历胃口,先满足胃口大的

               想象一下,你坐在一个椅子上,有的饼干为【1,3,5,9】,然后孩子的胃口为【1,2,7,10】.孩子们按照胃口从大到小的顺序来拿饼干,为了满足更多的小孩,就不要造成饼干尺寸的浪费,每个孩子来了你都给最大的

               10 来了  没有

               7  来了   给9

               2  来了   给5

               1  来了   给3


689ab9e8443b4632b030ad1703af56f6.png

  2、优先考虑饼干:孩子按照胃口从小到大来,给饼干也从小到大,给满足胃口即可,打发一个是一个

               拿出1  1可以

               拿出3   2可以

               拿出5   7不可以

               拿出9   7可以

5036c6abd06242f18b797ee09f42f245.png


分发饼干

优先考虑胃口

class Solution {
    public int findContentChildren(int[] g, int[] s) {
        Arrays.sort(g);
        Arrays.sort(s);
        // 饼干指针
        int sIndex = s.length - 1;
        // 胃口满足了的孩子的数量
        int count = 0;
        // 递减饼干
        for (int gIndex = g.length - 1; gIndex >= 0; gIndex--) {
            if (sIndex >= 0 && s[sIndex] >= g[gIndex]) {
                sIndex--;
                count++;
            }
        }
        return count;  
    }
}

优先考虑饼干

class Solution {
    public int findContentChildren(int[] g, int[] s) {
        Arrays.sort(g);
        Arrays.sort(s);
        int gIndex = 0;
        // 胃口满足了的孩子的数量
        int count = 0;
        for (int sIndex = 0; sIndex < s.length; sIndex++) {
            if (gIndex < g.length && s[sIndex] >= g[gIndex]) {
                count++;
                gIndex++;
            }
        }
        return count;     
    }
}


376. 摆动序列

题目链接:力扣

思路

删是不可能删的,核心思想一句话:记录满足峰值的的数字数量


       局部最优:满足峰值的,当一个值满足 左小右大 或者 左大右小 的时候进行记录


       全局最优:所有满足峰值情况的数字长度,就是摆动序列的数量,其他不符合要求的并没有记录


       对这里的条件还不是很理解


摆动序列

class Solution {
    public int wiggleMaxLength(int[] nums) {
        if (nums.length <= 1) {
            return nums.length;
        }
        // 目前一对数字的差值
        int curDiff = 0;
        // 前一对数字的差值
        int preDiff = 0;
        // 符合要求的数量
        int result = 1;
        for (int i = 0; i + 1 < nums.length; i++) {
            // 计算当前一对数字的差值
            curDiff = nums[i + 1] - nums[i];
            // 出现峰值的数字
            if ((curDiff > 0 && preDiff <= 0)||(preDiff >= 0 && curDiff < 0)) {
                result++;
                preDiff = curDiff;
            }
        }
        return result;
    }
}

在LeetCode上看到一个很绝的写法,特别妙,变相取峰值

class Solution {
    public int wiggleMaxLength(int[] nums) {
        int n = nums.length;
        if (n < 2) {
            return n;
        }
        int up = 1;
        int down = 1;
        for (int i = 1; i < n; i++) {
            if (nums[i] > nums[i - 1]) {
                up = down + 1;
            }
            if (nums[i] < nums[i - 1]) {
                down = up + 1;
            }
        }
        return Math.max(up, down);
    }
}

53. 最大子序和

题目链接:力扣

思路


 拿到题是真的没思路,能想到的最简单的就是使用回溯,但是会超出市场,应该使用其他方法


       然后看了一下题解,真的想的太复杂了,使用了暴力解法,但是超出时长了


       所以只好使用贪心算法,贪心算法的贪在于:只要当前和出现了负数,就会从0开始计数,因为负数只会降低“连续和”


最大子序和

暴力解法

超出时间限制 不可用

class Solution {
    public int maxSubArray(int[] nums) {
        int result = Integer.MIN_VALUE;
        for (int i = 0; i < nums.length; i++) {
            int sum = 0;
            for (int j = i; j < nums.length; j++) {
                sum += nums[j];
                if (sum > result) {
                    result = sum;
                }
            }
        }
        return result;
    }
}

贪心算法

class Solution {
    public int maxSubArray(int[] nums) {
        int result = Integer.MIN_VALUE;
        int count = 0;
        for (int i = 0; i < nums.length; i++) {
            count += nums[i];
            if (count > result) {
                result = count;
            }
            if (count < 0) {
                count = 0;
            }
        }
        return result;
    }
}
相关文章
|
26天前
|
机器学习/深度学习 算法
基于改进遗传优化的BP神经网络金融序列预测算法matlab仿真
本项目基于改进遗传优化的BP神经网络进行金融序列预测,使用MATLAB2022A实现。通过对比BP神经网络、遗传优化BP神经网络及改进遗传优化BP神经网络,展示了三者的误差和预测曲线差异。核心程序结合遗传算法(GA)与BP神经网络,利用GA优化BP网络的初始权重和阈值,提高预测精度。GA通过选择、交叉、变异操作迭代优化,防止局部收敛,增强模型对金融市场复杂性和不确定性的适应能力。
165 80
|
19天前
|
机器学习/深度学习 算法
基于遗传优化的双BP神经网络金融序列预测算法matlab仿真
本项目基于遗传优化的双BP神经网络实现金融序列预测,使用MATLAB2022A进行仿真。算法通过两个初始学习率不同的BP神经网络(e1, e2)协同工作,结合遗传算法优化,提高预测精度。实验展示了三个算法的误差对比结果,验证了该方法的有效性。
|
1月前
|
存储 算法 程序员
C 语言递归算法:以简洁代码驾驭复杂逻辑
C语言递归算法简介:通过简洁的代码实现复杂的逻辑处理,递归函数自我调用解决分层问题,高效而优雅。适用于树形结构遍历、数学计算等领域。
|
2月前
|
并行计算 算法 测试技术
C语言因高效灵活被广泛应用于软件开发。本文探讨了优化C语言程序性能的策略,涵盖算法优化、代码结构优化、内存管理优化、编译器优化、数据结构优化、并行计算优化及性能测试与分析七个方面
C语言因高效灵活被广泛应用于软件开发。本文探讨了优化C语言程序性能的策略,涵盖算法优化、代码结构优化、内存管理优化、编译器优化、数据结构优化、并行计算优化及性能测试与分析七个方面,旨在通过综合策略提升程序性能,满足实际需求。
80 1
|
2月前
|
算法
优化策略:揭秘钢条切割与饼干分发的算法艺术
本文探讨了钢条切割与饼干分发两个经典算法问题,展示了算法在解决实际问题中的应用。钢条切割问题通过动态规划方法,计算出不同长度钢条的最大盈利切割方式,考虑焊接成本后问题更为复杂。饼干分发问题则采用贪心算法,旨在尽可能多的喂饱孩子,分别讨论了每个孩子一块饼干和最多两块饼干的情况。这些问题不仅体现了数学的精妙,也展示了工程师的智慧与创造力。
51 4
|
2月前
|
存储 缓存 算法
通过优化算法和代码结构来提升易语言程序的执行效率
通过优化算法和代码结构来提升易语言程序的执行效率
|
2月前
|
算法
分享一些提高二叉树遍历算法效率的代码示例
这只是简单的示例代码,实际应用中可能还需要根据具体需求进行更多的优化和处理。你可以根据自己的需求对代码进行修改和扩展。
|
2月前
|
算法 测试技术 开发者
在Python开发中,性能优化和代码审查至关重要。性能优化通过改进代码结构和算法提高程序运行速度,减少资源消耗
在Python开发中,性能优化和代码审查至关重要。性能优化通过改进代码结构和算法提高程序运行速度,减少资源消耗;代码审查通过检查源代码发现潜在问题,提高代码质量和团队协作效率。本文介绍了一些实用的技巧和工具,帮助开发者提升开发效率。
58 3
|
2月前
|
分布式计算 Java 开发工具
阿里云MaxCompute-XGBoost on Spark 极限梯度提升算法的分布式训练与模型持久化oss的实现与代码浅析
本文介绍了XGBoost在MaxCompute+OSS架构下模型持久化遇到的问题及其解决方案。首先简要介绍了XGBoost的特点和应用场景,随后详细描述了客户在将XGBoost on Spark任务从HDFS迁移到OSS时遇到的异常情况。通过分析异常堆栈和源代码,发现使用的`nativeBooster.saveModel`方法不支持OSS路径,而使用`write.overwrite().save`方法则能成功保存模型。最后提供了完整的Scala代码示例、Maven配置和提交命令,帮助用户顺利迁移模型存储路径。
|
2月前
|
机器学习/深度学习 人工智能 自然语言处理
280页PDF,全方位评估OpenAI o1,Leetcode刷题准确率竟这么高
【10月更文挑战第24天】近年来,OpenAI的o1模型在大型语言模型(LLMs)中脱颖而出,展现出卓越的推理能力和知识整合能力。基于Transformer架构,o1模型采用了链式思维和强化学习等先进技术,显著提升了其在编程竞赛、医学影像报告生成、数学问题解决、自然语言推理和芯片设计等领域的表现。本文将全面评估o1模型的性能及其对AI研究和应用的潜在影响。
72 1

热门文章

最新文章