代码随想录训练营Day23:贪心算法1

2024-05-06 13:44

本文主要是介绍代码随想录训练营Day23:贪心算法1,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

贪心算法:选择每一个阶段的最优值从而达到一个全局最优

贪心算法的解题思路:

  1. 将问题分为若干个子问题
  2. 找出合适的贪心策略(核心)
  3. 求解每个子问题的最优解
  4. 将局部最优解堆叠成全局最优解

1.455分发饼干

贪心思路:两种分配原则:1.将大的先分给胃口大的。2.将小的先分给胃口小的

我们以第一种为例,首先就是对其进行一个排序,由于这个里面每个最多只能分配一个,从右往左遍历,找到大的饼干对应的满足胃口的那个进行分配从而实现全局最优。

class Solution {
public://因为在这个题目里面每个人最多只能分配一个,所以我们需要来确定相应的分配原则//1.将大的分配给大的,第二种是小的分配给小的int findContentChildren(vector<int>& g, vector<int>& s) {sort(g.begin(),g.end());sort(s.begin(),s.end());int m = g.size()-1;int n = s.size()-1;int sum = 0;for(int i = m;i>=0;i--){if(n>=0&&s[n]>=g[i]){n--;sum++;}}return sum;}
};

2.376摆动序列

摆动序列:如果连续数字之间的差严格地在正数和负数之间交替,则数字序列称为 摆动序列 

贪心策略三种情况:

  1. 两端
  2. 出现平的情况
  3. 出现正负交替的情况

针对这三种情况,我们设置两个变量preDiff和curDiff=nums[i]-nums[i-1]分别用来存储当前的差值和前面那段的差值。

默认情况下val = 1(默认nums[0]端点参与),preDiff和curDiff都是为0,preDiff = curDiff的情况,找到转折点的时候,进行更新

  1. i = 1的情况:preDiff = 0 ,curDiff <0 是转折点,curDiff = 0不是转折点,curDiff>0是转折点
  2. i!=1的情况:preDiff>0,curDiff<0是转折点,curDiff<=0不是转折点
  3. i!=1的情况:preDiff<0,curDiff>0是转折点,curDiff>=0不是转折点

将上面的情况进行综合就得到了下面的判断条件。

class Solution {
public://此题的思路就是在于找到当中的转折点//转折点分为三种情况:1.两端,两端是默认有一个转折点//2.有坡的情况:此时我们需要记录前面的坡度的情况//3.没坡的情况int wiggleMaxLength(vector<int>& nums) {int maxseries = 0;int n = nums.size();int prediff = 0;//记录的是预先的设定int curdiff = 0;int val = 1;for(int i=1;i<n;i++){curdiff = nums[i] - nums[i-1]; if((prediff>=0&&curdiff<0)||(prediff<=0&& curdiff>0)){val++;prediff = curdiff;}}return val;}
};

3.53最大子序和

贪心策略:计算起点的时候,前面一段连续子序和的值一定是正数或者0.如果当前的累加和小于0,那么就舍弃,重新从0开始。

使用maxs计算最大的子序和。count计算当前的子序和。如果count<0,则将其设置为0代表前面的舍弃。

class Solution {
public:int maxSubArray(vector<int>& nums) {int n = nums.size();if(n==0)return 0;if(n == 1)return nums[0];int maxs = nums[0];int count = 0;for(int i=0;i<n;i++){count += nums[i];if(count>maxs)maxs = count;//更新最大值if(count<0){count = 0;//更新起始位置}}return maxs;}
};

这篇关于代码随想录训练营Day23:贪心算法1的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/964517

相关文章

深入理解Mysql OnlineDDL的算法

《深入理解MysqlOnlineDDL的算法》本文主要介绍了讲解MysqlOnlineDDL的算法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小... 目录一、Online DDL 是什么?二、Online DDL 的三种主要算法2.1COPY(复制法)

Java集合之Iterator迭代器实现代码解析

《Java集合之Iterator迭代器实现代码解析》迭代器Iterator是Java集合框架中的一个核心接口,位于java.util包下,它定义了一种标准的元素访问机制,为各种集合类型提供了一种统一的... 目录一、什么是Iterator二、Iterator的核心方法三、基本使用示例四、Iterator的工

Java 线程池+分布式实现代码

《Java线程池+分布式实现代码》在Java开发中,池通过预先创建并管理一定数量的资源,避免频繁创建和销毁资源带来的性能开销,从而提高系统效率,:本文主要介绍Java线程池+分布式实现代码,需要... 目录1. 线程池1.1 自定义线程池实现1.1.1 线程池核心1.1.2 代码示例1.2 总结流程2. J

JS纯前端实现浏览器语音播报、朗读功能的完整代码

《JS纯前端实现浏览器语音播报、朗读功能的完整代码》在现代互联网的发展中,语音技术正逐渐成为改变用户体验的重要一环,下面:本文主要介绍JS纯前端实现浏览器语音播报、朗读功能的相关资料,文中通过代码... 目录一、朗读单条文本:① 语音自选参数,按钮控制语音:② 效果图:二、朗读多条文本:① 语音有默认值:②

Vue实现路由守卫的示例代码

《Vue实现路由守卫的示例代码》Vue路由守卫是控制页面导航的钩子函数,主要用于鉴权、数据预加载等场景,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着... 目录一、概念二、类型三、实战一、概念路由守卫(Navigation Guards)本质上就是 在路

uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)

《uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)》在uni-app开发中,文件上传和图片处理是很常见的需求,但也经常会遇到各种问题,下面:本文主要介绍uni-app小程序项目中实... 目录方式一:使用<canvas>实现图片压缩(推荐,兼容性好)示例代码(小程序平台):方式二:使用uni

JAVA实现Token自动续期机制的示例代码

《JAVA实现Token自动续期机制的示例代码》本文主要介绍了JAVA实现Token自动续期机制的示例代码,通过动态调整会话生命周期平衡安全性与用户体验,解决固定有效期Token带来的风险与不便,感兴... 目录1. 固定有效期Token的内在局限性2. 自动续期机制:兼顾安全与体验的解决方案3. 总结PS

C#中通过Response.Headers设置自定义参数的代码示例

《C#中通过Response.Headers设置自定义参数的代码示例》:本文主要介绍C#中通过Response.Headers设置自定义响应头的方法,涵盖基础添加、安全校验、生产实践及调试技巧,强... 目录一、基础设置方法1. 直接添加自定义头2. 批量设置模式二、高级配置技巧1. 安全校验机制2. 类型

Python屏幕抓取和录制的详细代码示例

《Python屏幕抓取和录制的详细代码示例》随着现代计算机性能的提高和网络速度的加快,越来越多的用户需要对他们的屏幕进行录制,:本文主要介绍Python屏幕抓取和录制的相关资料,需要的朋友可以参考... 目录一、常用 python 屏幕抓取库二、pyautogui 截屏示例三、mss 高性能截图四、Pill

使用MapStruct实现Java对象映射的示例代码

《使用MapStruct实现Java对象映射的示例代码》本文主要介绍了使用MapStruct实现Java对象映射的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,... 目录一、什么是 MapStruct?二、实战演练:三步集成 MapStruct第一步:添加 Mave