Day28 第八章 贪心算法 part01

news/2025/2/27 2:42:41

一. 学习文章及资料

  • 理论基础
  • 455.分发饼干
  • 376.摆动序列
  • 53.最大子序和

二. 学习内容

1. 理论基础

算法>贪心算法无规律!

一般如想到局部最优,好像能推出全局最优,并且无明显反例,那就试一试!

2. 分发饼干

(1) 解题思路:

使用贪心策略,先将饼干数组和小孩数组排序。然后从后向前遍历小孩数组,用大饼干优先满足胃口大的,并统计满足小孩数量。

                           

(2) 解题步骤:

class Solution {
    public int findContentChildren(int[] g, int[] s) {
        Arrays.sort(g);
        Arrays.sort(s);
        int result=0;
        int index=s.length-1;
        for(int i=g.length-1;i>=0;i--){
            if(index>=0&&s[index]>=g[i]){
                result++;
                index--;
            }
        }
        return result;
    }
}

3. 摆动序列

(1) 解题思路:
局部最优:删除单调坡度上的节点(不包括单调坡度两端的节点),那么这个坡度就可以有两个局部峰值。
全局最优:整个序列有最多的局部峰值,从而达到最长摆动序列。
实际操作上,只需统计数组的峰值数量就可以了(相当于是删除单一坡度上的节点,然后统计长度)

  • 情况一:上下坡中有平坡

  • 情况二:数组首尾两端

如只有两个不同数字,那默认最右边有峰值。如 [2,5], result 初始为 1(默认最右面有一个峰值),i为0,指向2,此时 curDiff > 0 && preDiff <= 0,那么 result++(计算了左面的峰值),最后得到的 result 就是 2(峰值个数为 2 即摆动序列长度为 2)

  • 情况三:单调坡中有平坡

在这个坡度摆动变化的时候,更新 preDiff 就行,这样 preDiff 在 单调区间有平坡的时候就不会发生变化,造成我们的误判。

class Solution {
    public int wiggleMaxLength(int[] nums) {
        if(nums.length<=1) return nums.length;
        int perDiff=0;//前一对差值
        int curDiff=0;//现一对差值
        int result=1; //记录峰值个数,序列默认序列最右边有一个峰值
        for(int i=0;i<nums.length-1;i++){//只遍历到倒数第二个,因为默认序列最右边有一个峰值
            curDiff=nums[i+1]-nums[i];
            //出现峰值
            if(perDiff>=0&&curDiff<0||perDiff<=0&&curDiff>0){
                result++;
                perDiff=curDiff;//注意这里,只在摆动变化的时候更新prediff
            }
        }
        return result;
    }
}

4. 最大子序和

(1) 解题思路:

局部最优:当前“连续和”为负数的时候立刻放弃,从下一个元素重新计算“连续和”,因为负数加上下一个元素 “连续和”只会越来越小。
全局最优:选取最大“连续和”
局部最优的情况下,并记录最大的“连续和”,可以推出全局最优

                       

class Solution {
    public int maxSubArray(int[] nums) {
        int result=Integer.MIN_VALUE;
        int sum=0;
        for(int i=0;i<nums.length;i++){
            sum+=nums[i];
            if(sum>result) result=sum;//取区间累计的最大值(相当于不断确定最大子序终止位置)
            if(sum<0) sum=0; //相当于重置最大子序起始位置,因为遇到负数一定是拉低总和
        }
        return result;
    }
}


http://www.niftyadmin.cn/n/5869400.html

相关文章

Ubuntu部署ktransformers

准备工作 一台服务器 CPU&#xff1a;500G GPU&#xff1a;48G&#xff08;NVIDIA4090&#xff09; 系统&#xff1a;Ubuntu20.04&#xff08;github的文档好像用的是22.04&#xff09; 第一步&#xff1a;下载权重文件 1.下载hfd wget https://hf-mirror.com/hfd/hfd.s…

FFmpeg.NET:.NET 平台上的音视频处理利器

FFmpeg.NET 是一个封装了 FFmpeg 功能的 .NET 库&#xff0c;能够方便地在 C# 项目中处理音视频文件。它支持多种操作&#xff0c;包括转码、剪辑、合并、分离音频等。 功能 解析元数据从视频生成缩略图使用以下参数将音频和视频转码为其他格式&#xff1a; 码率&#xff08;…

微信小程序网络请求与API调用:实现数据交互

在前几篇文章中,我们学习了微信小程序的基础知识、数据绑定、事件处理以及页面导航与路由。这些知识帮助我们构建了具备基本交互功能的小程序。然而,一个完整的应用通常需要与服务器进行数据交互,例如获取用户信息、提交表单数据等。本文将深入探讨微信小程序的网络请求与AP…

计算机网络之路由协议(OSPF路由协议)

一、定义与分类 OSPF是一种内部网关协议&#xff08;IGP&#xff09;&#xff0c;也属于链路状态路由协议。它使用链路状态路由算法&#xff0c;在单一自治系统&#xff08;AS&#xff09;内部工作。适用于IPv4的OSPFv2协议定义于RFC2328&#xff0c;而RFC5340则定义了适用于I…

基于Qlearning强化学习的2DoF机械臂运动控制系统matlab仿真

目录 1.算法仿真效果 2.算法涉及理论知识概要 2.1 2DoF机械臂运动学模型 2.2 Q-learning强化学习算法原理 3.MATLAB核心程序 4.完整算法代码文件获得 1.算法仿真效果 matlab2022a仿真结果如下&#xff08;完整代码运行后无水印&#xff09;&#xff1a; 仿真操作步骤可参…

深入解析 Linux /etc/skel 目录的作用与使用方法

在 Linux 系统中&#xff0c;用户的主目录通常存放着一系列个人配置文件&#xff0c;如 .bashrc、.profile 等&#xff0c;这些文件影响着用户的 Shell 环境、别名、环境变量等。而当我们创建新用户时&#xff0c;这些默认的配置从何而来&#xff1f;这正是 /etc/skel 目录发挥…

国内访问Github的四种方法(2025版)

声明&#xff1a;以下内容&#xff0c;仅供学习使用&#xff0c;不得他用。如有他用&#xff0c;与本文作者无关。 国内访问GitHub及下载文件的解决方案整理如下&#xff0c;结合最新技术方案和实测有效方法&#xff1a; 一、网络层解决方案 Hosts文件修改法 通过DNS查询工具…

海康摄像头 + M7s(Monibuca) + FFmpeg + Python实现多个网络摄像头视频流推流

最近在研究流媒体服务器时&#xff0c;我注意到了一款开源软件——M7s。按照官网的指南部署完成后&#xff0c;我开始进行测试&#xff0c;发现单视频流推送非常顺利&#xff0c;没有任何问题。然而&#xff0c;当我尝试进行多视频流推送时&#xff0c;却发现网上的相关教程寥寥…