代码随想录 day31|day32

分发饼干
题意:
对每个孩子 i,都有一个胃口值 g[i],这是能让孩子们满足胃口的饼干的最小尺寸;并且每块饼干 j,都有一个尺寸 s[j] 。如果 s[j] >= g[i],我们可以将这个饼干 j 分配给孩子 i ,这个孩子会得到满足。
思路:
1.先排序; 然后对每个小孩尝试找到让饼干满足的尺寸。
2.一个while循环是针对某个小孩找到第一个能满足要求的饼干。

        for(int i = 0  , j = 0; i < g.size() && j < s.size() ; ++ i)
        {
         
           while( j< s.size() && s[j] - g[i] < 0 )
            {
                 
                 j++ ;    
            } // 找到第一个能达到要求的饼干。 
            // 如果饼干能满足要求那么就j++ ; 并且被满足的小孩总数目加加。  
            if(j < s.size() && s[j] - g[i] >= 0)
            {
                manum++ ; 
                j++ ; 

摆动序列
题意是找到最长摆动子序列的长度。
画图
在这里插入图片描述

贪心策略:找到局部最优:curdif 和 predif 的规定。 删除单一坡度上的节点这样就只剩下摆动序列,之后找到全局最优。 全局最优是删除全部的单调坡度。

class Solution {
public:
    int wiggleMaxLength(vector<int>& nums) {
        if (nums.size() <= 1) return nums.size();
        int curDiff = 0; // 当前一对差值
        int preDiff = 0; // 前一对差值
        int result = 1;  // 记录峰值个数,序列默认序列最右边有一个峰值
        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; // 只有在有摆动时,才将predif = curdif 
            }
         
        }
        return result;
    }
};

最大子序和
题意:
是找出一个具有最大和的连续子数组。
思路:
局部贪心:每次认为本次寻找的是最大的和。但是如果求得的和小于0;那么就重置为0(证明本次没有找到最大和), 又重新更新最大值。 这就造成了全局贪心:找到全局的最大和。
代码

int maxSubArray(vector<int>& nums) 
    {
        int res =0  , maxres = INT_MIN ; 
        if(nums.size() == 1)
        {
            return nums[0] ; 
        }
        for(int i = 0  ;i< nums.size() ; ++ i)
        {
            res += nums[i] ;         
            if(maxres < res) // 找到最大值。 
            {
                maxres = res ; 
            }
            if(res <= 0) // 证明本次没找到最大值。
            { 
                res = 0  ; 
            }
        }

        return maxres ; 
    }

买卖股票的最佳时机 II
题意:给你一个整数数组 prices ,其中 prices[i] 表示某支股票第 i 天的价格。在每一天,你可以决定是否购买和/或出售股票。你在任何时候 最多 只能持有 一股 股票。你也可以先购买,然后在 同一天 出售。返回 你能获得的 最大 利润 。
思路:
局部:对每个上升期的股票取得最大利润。
全局:达到最佳最大利润。
具体:如果prices[i-1] > prices[i] 就表示 此时是收割i-1到之前的利润的时候,本次的最大利润就是这个值。 最终得到最大利润。
但是卡哥的更简洁
所以这里列出卡哥的思路:
最终的利润可以分解成每天的利润 ; 如果这天的利润为正加入结果集。

int maxProfit(vector<int>& prices) {
        int result = 0;
        for (int i = 1; i < prices.size(); i++) {
            result += max(prices[i] - prices[i - 1], 0);
        }
        return result;
    }


跳跃游戏
题意:给定一个非负整数nums ; 最初位于数组的第一个下标。
数组中的每个元素代表你在该位置可以跳跃的最大长度。
判断你是否能够到达最后一个下标,如果可以,返回 true ;否则,返回 false 。
思路:这个题需要绕一下;从跳跃,转换(映射)到求覆盖范围。
能否到达最后一个下标。并非是求最大的跳跃值。而是求能跳的最大的范围。 这个需要绕一下。
局部:每个元素的跳跃范围 i + nums[i] ; 在这个范围内找到下一次跳跃的最大范围。
之后全局最优。看最大范围是否到最尾元素。

int net =0 , cur = 0 ;  
for(int i = 0 ; i < nums.szie() ; ++ i)
{
net =  max(nums[i] +i , net) ; 
	if(cur>=nums.size() -1 )
	{
	return true; 
	}
	if(i == cur)
	{
		cur = net ; 
				
	}
}

跳跃游戏 II
题意:找到能够跳跃到最后元素的最少次数。
思路:依然是找到能够跳到的最大的范围;
局部最优和全局最优依然是上一题:
每次在该范围内找到下一次的最大的范围。
在每次跳的时候也是改变范围的时候(这也是绕的一点)

 int times  = 0,  cur = 0 , net = 0  ;  
        for(int i = 0 ; i< nums.size() ; ++ i)
        {
            if(cur >= nums.size()-1)
            {
                break ; 
            }
            net = max(nums[i] + i , net); // 计算下一次要遍历的范围的末尾此处是贪心思想的体现。
            if(cur == i && cur != nums.size()-1 ) // 如果cur 为 i 时 
            {
                cur  =  net ; 
                times ++ ; 
            }
        }
        return times ; // 进行返回 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/715350.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

go的netpoll学习

go的运行时调度框架简介 Go的运行时&#xff08;runtime&#xff09;中&#xff0c;由调度器管理&#xff1a;goroutine&#xff08;G&#xff09;、操作系统线程&#xff08;M&#xff09;和逻辑处理器&#xff08;P&#xff09;之间的关系 以实现高效的并发执行 当一个gorout…

netty:promise的简单示例

# 项目代码资源&#xff1a; 可能还在审核中&#xff0c;请等待。。。 https://download.csdn.net/download/chenhz2284/89442495 # 项目代码 【pom.xml】 <dependency><groupId>io.netty</groupId><artifactId>netty-all</artifactId><v…

基于JSP技术的个人网站系统

开头语&#xff1a; 你好呀&#xff0c;我是计算机学长猫哥&#xff01;如果有相关需求&#xff0c;文末可以找到我的联系方式。 开发语言&#xff1a;Java 数据库&#xff1a;MySQL 技术&#xff1a;JSP JavaBeans Servlet 工具&#xff1a;Eclipse、MySQL Workbench、…

nginx配置ssl证书

nginx配置ssl证书 1.官网下载 nginx官网下载地址 下载后&#xff0c;放到指定某一文件夹下并解压缩&#xff0c;之后cmd进入解压后的目录下&#xff0c;执行start nginx.exe命令 start nginx.exe然后在浏览器中访问默认监听80端口 http://localhost:80 浏览器访问有nginx表…

System-Verilog 实现DE2-115 流水灯

文章目录 一、什么是SystemVerilog二、代码实现实现结果 一、什么是SystemVerilog SystemVerilog是一种硬件描述语言(HDL)&#xff0c;它用于设计和验证电子系统&#xff0c;特别是在集成电路(IC)和系统级芯片(SoC)的设计过程中。SystemVerilog是Verilog语言的一个超集&#xf…

Photoshop中图像美化工具的应用

Photoshop中图像美化工具的应用 Photoshop中的裁剪工具Photoshop中的修饰工具模糊工具锐化工具涂抹工具 Photoshop中的颜色调整工具减淡工具加深工具海绵工具 Photoshop中的修复工具仿制图章工具污点修复画笔工具修复画笔工具修补工具内容感知移动工具红眼工具 Photoshop中的裁…

电子设计教程基础篇(电容)

文章目录 前言一、电容原理1.原理2.公式 二、电容种类1.结构1、固定电容2、可变电容3、微调电容 2.介质材料1、气体介质电容1、空气电容2、真空电容3、充气式电容 2、固体介质电容1、无机1、云母电容2、陶瓷电容1、瓷片电容2、独石电容 3、玻璃釉电容&#xff08;CI&#xff09…

韩顺平0基础学java——第24天

p484-508 System类 常见方法 System.arrycopy&#xff08;src&#xff0c;0&#xff0c;dest&#xff0c;1,2&#xff09;&#xff1b; 表示从scr的第0个位置拷贝2个&#xff0c;放到目标数组索引为1的地方。 BigInteger和BigDecimal类 保存大整数和高精度浮点数 BigInte…

ubuntu中安装docker并换源

使用 Ubuntu 的仓库安装 Docker sudo apt update现在&#xff0c;你可以使用以下命令在 Ubuntu 中安装 Docker 以及 Docker Compose&#xff1a; sudo apt install docker.io docker-composeDocker 包被命名为 docker.io&#xff0c;因为在 Docker 出现之前就已经存在一个名为…

pytorch学习笔记6

想要找一些官方的小工具数据集&#xff0c;可以进入pytorch官网&#xff0c;DOCS-》pytorch下拉至libraries&#xff0c;点击torchversion&#xff0c;调整版本至0.9.0就可以找到相应的一些数据集&#xff0c;训练集 ctrlp可以看一个函数中需要设置哪些参数 下载数据集可以参考…

如何解决javadoc一直找不到路径的问题?

目录 一、什么是javadoc二、javadoc为什么会找不到路径三、如何解决javadoc一直找不到路径的问题 一、什么是javadoc Javadoc是一种用于生成Java源代码文档的工具&#xff0c;它可以帮助开发者生成易于阅读和理解的文档。Javadoc通过解析Java源代码中的注释&#xff0c;提取其…

C++并发之锁(std::lock_guard,std::unique_lock)

目录 1 概述2 使用实例3 接口使用3.1 lock_guard3.2 adopt_lock3.3 defer_lock3.4 try_to_lock3.5 try_lock3.6 release3.7 lock3.8 call_one1 概述 锁保护是通过使互斥对象始终处于锁定状态来管理互斥对象的对象。。   在构造时,互斥对象被调用线程锁定,在析构时,互斥被解…

集成学习方法:Bagging与Boosting的应用与优势

个人名片 &#x1f393;作者简介&#xff1a;java领域优质创作者 &#x1f310;个人主页&#xff1a;码农阿豪 &#x1f4de;工作室&#xff1a;新空间代码工作室&#xff08;提供各种软件服务&#xff09; &#x1f48c;个人邮箱&#xff1a;[2435024119qq.com] &#x1f4f1…

Unity C#调用Android,IOS震动功能

最近在Unity上需要很原生移动端进行交互&#xff0c; 原理&#xff1a;新建一个android项目&#xff0c;把生成的app module给干掉&#xff0c;然后留下一个vibrationPlugin module&#xff0c;在这个module下写android震动代码&#xff0c;将这个android工程构建出来的 aar移…

17个关键方法指南,保护您的web站点安全!

了解如何让您的web应用程序或网站安全&#xff0c;对于网站所有者来说至关重要。以下是一些关键步骤&#xff0c;可以帮助您保护网站免受攻击和数据泄露。 1.使用公钥加密技术 当数据以明文形式传输时&#xff0c;它容易受到中间人 &#xff08;MitM&#xff09; 攻击。这意味…

计算机网络:网络层 - 路由选择协议

计算机网络&#xff1a;网络层 - 路由选择协议 路由器的结构路由选择协议概述自治系统 AS内部网关协议路由信息协议 RIP距离向量算法RIP报文格式收敛问题 开放最短路径优先 OSPF基本工作原理自治系统分区 外部网关协议BGP-4 路由器的结构 如图所示&#xff0c;路由器被分为路由…

【three.js】设置canvas画布背景透明

通过Three.js渲染一个模型的时候&#xff0c;不希望canvas画布有背景颜色&#xff0c;也就是canvas画布完全透明&#xff0c;可以透过canvas画布看到画布后面叠加的HTML元素图文&#xff0c;呈现出来一种三维模型悬浮在网页上面的效果。 比如我们现在的模型背景是黑色的&#…

数据库概述1

数据&#xff1a;描述事物的符号记录称为数据&#xff1b; 包括数字、图片、音频等&#xff1b; 数据库&#xff1a;长期储存在计算机内有组织、可共享的大量数据的集合&#xff1b;数据库中的数据按照一定的数据模型组织、描述和存储&#xff0c;具有较小的数据冗余、较高的数…

AI玩具来了,它怎么样?

90后的我们&#xff0c;是AI时代的见证者。20后的小孩&#xff0c;才是AI时代的原著民。当ChatGPT们改变着大人的工作方式&#xff0c;我觉得&#xff0c;是时候让孩子们的玩具也更聪明些了吧。于是&#xff0c;在六一前夕&#xff0c;我用市面上的AI语音对话套件给娃DIY了一套…

简单谈谈云服务器私网IP的存在意义及优势

云服务器是基于虚拟化技术的计算资源&#xff0c;可以在云平台上灵活创建和管理。为了满足不同用户的需求&#xff0c;云服务提供商在云服务器上分配了两种类型的IP地址&#xff1a;公网IP和私网IP。其中&#xff0c;私网IP是指在局域网内使用的内部IP地址&#xff0c;无法通过…