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

目录

一、455. 分发饼干

二、376. 摆动序列

三、53. 最大子数组和


贪心理论:模拟感觉可以局部最优推出整体最优,而且想不到反例,那么就试一试贪心

一、455. 分发饼干

题目链接:力扣

文章讲解:代码随想录

视频讲解:

题目:

假设你是一位很棒的家长,想要给你的孩子们一些小饼干。但是,每个孩子最多只能给一块饼干。

对每个孩子 i,都有一个胃口值 g[i],这是能让孩子们满足胃口的饼干的最小尺寸;并且每块饼干 j,都有一个尺寸 s[j] 。如果 s[j] >= g[i],我们可以将这个饼干 j 分配给孩子 i ,这个孩子会得到满足。你的目标是尽可能满足越多数量的孩子,并输出这个最大数值。

代码:

class Solution {
public:int findContentChildren(vector<int>& g, vector<int>& s) {sort(g.begin(), g.end());sort(s.begin(), s.end());int count = 0;for(int biscuits  = s.size()-1, child = g.size()-1; biscuits >= 0 && child >= 0; child--){if(s[biscuits] >= g[child]){biscuits--;count++;}}return count;}
};

时间复杂度: O(mlogm+nlogn)                                                  空间复杂度O(logm+logn)

⏲:2:47

总结:局部最优--小尺寸的饼干优先给小胃口的小孩,小胃口满足不了大胃口也满足不了,全局最优--小胃口都喂饱,饼干剩余部分为小胃口满足不了的,小孩剩余部分每个人胃口都比已满足的人大。

二、376. 摆动序列

题目链接:力扣

文章讲解:代码随想录

视频讲解:

题目:如果连续数字之间的差严格地在正数和负数之间交替,则数字序列称为 摆动序列 。第一个差(如果存在的话)可能是正数或负数。仅有一个元素或者含两个不等元素的序列也视作摆动序列。
例如, [1, 7, 4, 9, 2, 5] 是一个 摆动序列 ,因为差值 (6, -3, 5, -7, 3) 是正负交替出现的。
相反,[1, 4, 7, 2, 5] 和 [1, 7, 4, 5, 5] 不是摆动序列,第一个序列是因为它的前两个差值都是正数,第二个序列是因为它的最后一个差值为零。
子序列 可以通过从原始序列中删除一些(也可以不删除)元素来获得,剩下的元素保持其原始顺序。
给你一个整数数组 nums ,返回 nums 中作为 摆动序列 的 最长子序列的长度 。

代码:

class Solution {
public:int wiggleMaxLength(vector<int>& nums) {//根据峰值判断if (nums.size() < 2) return nums.size();int prediff = nums[1] - nums[0];int ans = prediff != 0 ? 2 : 1;for (int i = 2; i < nums.size(); i++){int diff = nums[i] - nums[i-1];if((diff > 0 && prediff <= 0) || (diff < 0 && prediff >= 0)){ans++;prediff = diff;}}return ans;//用新数组重新构造摆动序列/*vector<int> new_nums;int judge = -1;new_nums.push_back(nums[0]);for(int i = 1; i < nums.size(); i++){if(nums[i] > nums[i-1]){if(judge == 1){while(judge == 1 && i < nums.size()-1){i++;if(nums[i] < nums[i-1]) judge = 0;}new_nums.pop_back();if (judge == 1){new_nums.push_back(nums[i]);return new_nums.size();}new_nums.push_back(nums[i-1]);new_nums.push_back(nums[i]);}else{judge = 1;new_nums.push_back(nums[i]);}}else if(nums[i] < nums[i-1]){if(judge == 0){while(judge == 0 && i < nums.size()-1){i++;if(nums[i] > nums[i-1]) judge = 1;}new_nums.pop_back();if (judge == 0){new_nums.push_back(nums[i]);return new_nums.size();}new_nums.push_back(nums[i-1]);new_nums.push_back(nums[i]);}else{judge = 0;new_nums.push_back(nums[i]);}}}return new_nums.size();*/
}
};

时间复杂度: O(n)                                                  空间复杂度O(1)

⏲:19:20

总结:局部最优--峰与谷,全局最优--只有峰与谷。难点 1.峰与谷的转换:差值大于0和小于0。2.第一个峰还是谷与平坡的情况:通过predif的更新位置保障平坡的判断只可能在第一次中出现。

三、53. 最大子数组和

题目链接:力扣

文章讲解:代码随想录

视频讲解:

题目:如果连续数字之间的差严格地在正数和负数之间交替,则数字序列称为 摆动序列 。第一个差(如果存在的话)可能是正数或负数。仅有一个元素或者含两个不等元素的序列也视作摆动序列。
例如, [1, 7, 4, 9, 2, 5] 是一个 摆动序列 ,因为差值 (6, -3, 5, -7, 3) 是正负交替出现的。
相反,[1, 4, 7, 2, 5] 和 [1, 7, 4, 5, 5] 不是摆动序列,第一个序列是因为它的前两个差值都是正数,第二个序列是因为它的最后一个差值为零。
子序列 可以通过从原始序列中删除一些(也可以不删除)元素来获得,剩下的元素保持其原始顺序。
给你一个整数数组 nums ,返回 nums 中作为 摆动序列 的 最长子序列的长度 。

代码:

class Solution {
public:int maxSubArray(vector<int>& nums) {int ans = nums[0];int sum = nums[0];for(int fast = 1; fast < nums.size(); fast++){sum = max(nums[fast], sum+nums[fast]);if(sum > ans) ans = sum;}return ans;}
};

时间复杂度: O(n)                                                  空间复杂度O(1)

⏲:17:55

总结:局部最优--连续相加的数,或者最大的数本身。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

基于tcp协议的网络通信(将服务端守护进程化)

目录 守护进程化 引入 介绍 如何实现 思路 接口 -- setsid 注意点 实现代码 daemon.hpp log.hpp 运行情况 前情提要 -- 前后台任务介绍(区别命令),sessionsid介绍,session退出后的情况(nuhup,终端进程控制组),任务进程组概念,任务与进程组的关系,-bash介绍-CSDN博客…

ros找不到生成的可执行文件[rosrun] Couldn‘t find executable named hello_world_cpp below

catkin_make之后source ./devel/setup.bash source之后运行节点的时候,ros找不到可执行文件&#xff08;其实tab键补不齐就没找到了&#xff09; 手动查找发现生成的可执行文件在build下不在devel/lib下&#xff0c;所以白source&#xff0c;压根找不到。 查找原因说是因为CMa…

java项目将静态资源中的文件转为浏览器可访问的http地址

新增一个类叫啥无所谓&#xff0c;主要是实现 WebMvcConfigurer 加上注解 Configuration项目启动时加入bean中 只操作addResourceHandlers这一个方法 其他都没用 文章下方附带一个简易的上传图片代码 package cn.exam.config;import org.springframework.context.annotati…

【P4924】[1007] 魔法少女小Scarlet

[1007] 魔法少女小Scarlet 题目描述 Scarlet 最近学会了一个数组魔法&#xff0c;她会在 n n n\times n nn 二维数组上将一个奇数阶方阵按照顺时针或者逆时针旋转 9 0 ∘ 90^\circ 90∘。 首先&#xff0c;Scarlet 会把 1 1 1 到 n 2 n^2 n2 的正整数按照从左往右&…

Linux线程补充——周边问题

一、线程池 ​ 使用多线程时要注意传参传递堆空间指针变量&#xff1b; ​ 平常定义的缓冲区就是一个简单的数据池&#xff1b;malloc的底层调用了系统调用来申请堆空间是有成本的&#xff0c;如&#xff1a;需要使用页表和MMU将虚拟地址和物理地址建立映射&#xff0c;期间会…

蓝桥杯刷题记录之数字王国之军训排队

记录 卡了半天&#xff0c;check函数中的temp % ele 0写成了ele % temp 0就挺无语的 思路 这个晚上在补 代码 import java.util.*; public class Main{static List<List<Integer>> que new ArrayList<>();static int MIN Integer.MAX_VALUE;static i…

Personal Website

Personal Website Static Site Generators hexo hugo jekyll Documentation Site Generator gitbook vuepress vitepress docsify docute docusaurus Deployment 1. GitHub Pages 2. GitLab Pages 3. vercel 4. netlify Domain 域名注册 freessl 域名解析域名…

Java基础面试整理

1. Java的跨平台优势&#xff1f; 写好的Java源文件通过Javac命令编译生成class文件(中间文件)&#xff0c;然后JVM对class文件进行执行生成机器语言然后机器语言在平台中操作&#xff0c;Java在不同的平台下都有对应的不同版本的JVM&#xff0c;JVM可以识别字节码文件从而运行…

DMA控制器

前言 大家好&#xff0c;我是jiantaoyab&#xff0c;这是我作为学习笔记的25篇&#xff0c;本篇文章给大家介绍DMA。 无论 I/O 速度如何提升&#xff0c;比起 CPU&#xff0c;总还是太慢。如果我们对于 I/O 的操作&#xff0c;都是由 CPU 发出对应的指令&#xff0c;然后等待…

带气压高度的三点法MATLAB定位函数(基于加权最小二乘法WLS)

函数作用 输入气压高度值、待定位节点与各个锚节点的距离、锚节点位置、权重&#xff08;可选&#xff09;&#xff0c;输出待测点位置 程序源码 function [p_out] triposition_weight_Ver2(dairheight,R_calcu,baseP,varargin) % airghight 由气压高度计算的锚节点-待测节…

【数据结构】线性表的定义与基本操作

&#x1f388;个人主页&#xff1a;豌豆射手^ &#x1f389;欢迎 &#x1f44d;点赞✍评论⭐收藏 &#x1f917;收录专栏&#xff1a;数据结构 &#x1f91d;希望本文对您有所裨益&#xff0c;如有不足之处&#xff0c;欢迎在评论区提出指正&#xff0c;让我们共同学习、交流进…

用户态和内核态:操作系统权限与运行模式解析

在现代计算机操作系统中&#xff0c;用户态&#xff08;User Mode&#xff09;和内核态&#xff08;Kernel Mode&#xff09;是两种重要的运行模式&#xff0c;用于区分用户程序与操作系统核心之间的权限和特权级别。深入理解这两种模式对于理解操作系统的工作原理至关重要。 …

关于vector的size,unsigned int类型

平时写代码很少注意溢出&#xff0c;这次被遇上了。 题目&#xff1a;. - 力扣&#xff08;LeetCode&#xff09; class Solution { public:bool containsNearbyDuplicate(vector<int>& nums, int k) {//超时,O(n2)// for(int i0;i<nums.size();i)// {// fo…

学习次模函数-第2章 定义

纵观本专著&#xff0c;我们认为及其幂集&#xff08;即&#xff0c; 所有子集的集合&#xff09;&#xff0c;其基数为。我们也考虑一个实值集函数&#xff0c;使得。 与凸函数的一般约定相反&#xff08;见附录A&#xff09;&#xff0c;我们不允许函数有无穷大的值。 次模分…

ssm004新生报到系统+jsp

新生报到系统的设计与实现 摘 要 互联网发展至今&#xff0c;无论是其理论还是技术都已经成熟&#xff0c;而且它广泛参与在社会中的方方面面。它让信息都可以通过网络传播&#xff0c;搭配信息管理工具可以很好地为人们提供服务。针对新生报到信息管理混乱&#xff0c;出错率…

虚拟线圈法的车辆统计_3.12

目标 车流量统计的方法实现车流量检测 基于虚拟线圈法的车辆统计是一种利用计算机视觉技术模拟传统物理线圈检测原理&#xff0c;对交通视频流中的车辆进行计数的方法。在传统交通监控系统中&#xff0c;物理线圈是通过感应车辆经过时产生的电磁场变化来记录车辆流量。这种方式…

基于深度学习的图像分类方法

基于深度学习的图像分类方法已经成为计算机视觉领域的重要组成部分。这类方法通常涉及使用深度神经网络&#xff0c;特别是卷积神经网络&#xff08;CNNs&#xff09;来识别和分类图像中的对象。以下是基于深度学习的图像分类方法的一些关键要点&#xff1a; 卷积神经网络&…

数据库ER图和ER图转换关系模式

ER图&#xff08;Entity-Relationship Diagram&#xff09;是一种用于描述实体&#xff08;Entity&#xff09;之间关系的图形化工具。ER图是由实体、属性和关系组成的。 实体&#xff08;Entity&#xff09;指的是现实世界中的一个对象或概念&#xff0c;如人、物、事件等。每…

安全问题

信息安全具有不可证明的特性&#xff0c;只能说在某些已知攻击下是安全的&#xff0c;对于将来新的攻击是否安全仍然很难断言。 信息系统不安全的主要因素有程序设计漏洞、用户操作不当和外部攻击。外部攻击形式主要有计算机病毒、恶意软件、黑客攻击等。目前计算机系统在理论…

模型怎么处理不同尺寸的输入图像

1.有全连接层的的CNN模型 卷积能够处理不同尺寸的输入图像&#xff0c;但全连接层不行&#xff0c;因此在送入全连接层之前需将卷积层提取的特征转换为一个固定长度的特征向量。 那么如何转换&#xff1f; 1.1 GAP(Global Average Pooling)全局平均池化 直接代码举例&#…