当前位置: 首页 > news >正文

台州网站制作台州网站建设百度普通下载

台州网站制作台州网站建设,百度普通下载,做外贸在那些网站找客户,如何开淘宝店做国外网站代码随想录算法训练营 —day27 文章目录 代码随想录算法训练营前言一、贪心算法理论基础二、455.分发饼干三、376. 摆动序列53. 最大子数组和总结 前言 今天是算法营的第27天,希望自己能够坚持下来! 今日任务: ● 贪心算法理论基础 ● 455.…

代码随想录算法训练营

—day27

文章目录

  • 代码随想录算法训练营
  • 前言
  • 一、贪心算法理论基础
  • 二、455.分发饼干
  • 三、376. 摆动序列
  • 53. 最大子数组和
  • 总结


前言

今天是算法营的第27天,希望自己能够坚持下来!
今日任务:
● 贪心算法理论基础
● 455.分发饼干
● 376. 摆动序列
● 53. 最大子序和


一、贪心算法理论基础

文章讲解
视频讲解

题目大纲:
在这里插入图片描述

贪心的本质是选择每一阶段的局部最优,从而达到全局最优。
贪心没有套路,说白了就是常识性推导加上举反例。贪心的题目要么很简单,要么没做过就想不出来思路。遇到没思路的题目不要想太久,马上看题解积累思路。


二、455.分发饼干

题目链接
文章讲解
视频讲解

思路:

  1. 这里的局部最优是,尽量用大的饼干去满足大的胃口(或者反过来用小的饼干满足小的胃口)
  2. 先对饼干和胃口排序
  3. 从后往前遍历胃口,优先用最大的饼干去匹配大胃口
  4. 如果满足的话则饼干index往前(这里要注意index>=0),累加计数。

代码如下:

class Solution {
public:int findContentChildren(vector<int>& g, vector<int>& s) {//先排列,升序sort(g.begin(), g.end());sort(s.begin(), s.end());int index = s.size() - 1;int result = 0;for (int i = g.size() - 1; i >= 0; i--) { //遍历胃口if (index >= 0 && s[index] >= g[i]) { //遍历饼干,用最大的饼干匹配index--;result++;}}return result;}
};

三、376. 摆动序列

题目链接
文章讲解
视频讲解

在这里插入图片描述
局部最优:删除单调坡度上的节点(不包括单调坡度两端的节点),那么这个坡度就可以有两个局部峰值(头和尾)。

整体最优:整个序列有最多的局部峰值,从而达到最长摆动序列。

因为题目要求的是最长摆动子序列的长度,所以只需要统计数组的峰值数量就可以了

思路:

  1. 用当前元素分别和前一元素,后一元素的差的正负来判断是否有摆动;
  2. preDiff = nums[i + 1] - nums[i],curDiff = nums[i] - nums[i - 1];
  3. preDiff和curDiff一正一负时说明出现了摆动。

这是我们思考本题的一个大体思路,但本题要考虑三种情况:
情况一:上下坡中有平坡
在这里插入图片描述
平坡有4个2,那么考虑删掉左边3个2的话,遍历到最后一个2时的条件就是prediff = 0 && curdiff < 0,所以判断峰值的条件就应该是:
(preDiff <= 0 && curDiff > 0) || (preDiff >= 0 && curDiff < 0)

情况二:数组首尾两端
在这里插入图片描述
题目中说了,如果只有两个不同的元素,那摆动序列也是 2。
那么为了统计到这种情况,默认最右端是一个摆动,result初始化为1,且遍历只遍历到倒数第二个,i < nums.size() - 1;再加上情况一讨论的判断条件 curDiff > 0 && preDiff <= 0,那么result++,就会得到答案2.

情况三:单调坡中有平坡
在这里插入图片描述
为了避免nums[1]和nums[2]都各自统计了一次摆动,只需要在这个坡度摆动变化的时候,更新 prediff 就行(也就是图上的1),这样 prediff 在 单调区间有平坡的时候 就不会发生变化,造成我们的误判。

class Solution {
public:int wiggleMaxLength(vector<int>& nums) {if (nums.size() <= 1) return nums.size();int preDiff = 0; //nums[i + 1] - nums[i]int curDiff = 0; //nums[i] - nums[i - 1]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; //当遇到摆动变化时才更新prediff}}return result;}
};

53. 最大子数组和

题目链接
文章讲解
视频讲解

思路:

  1. 当累加和是负数时,继续往后加都是让后面的数更加小
  2. 所以当累加和为负时,舍弃掉当前的累加,重新从下一个元素开始累加,并且在过程中记录累加的最大值。

代码如下:

class Solution {
public:int maxSubArray(vector<int>& nums) {int result = INT_MIN;int count = 0;for (int i = 0; i < nums.size(); i ++) {count += nums[i]; //计算累加值if (count > result) result = count; //记录最大值if (count < 0) count = 0; //当连续和为负数时,舍弃累加值,重新累加}return result;}
};

总结

今天第一天的贪心算法,代码其实都不难,难的是思路,需要多积累一些解题思路才行。

明天继续加油!

http://www.tj-hxxt.cn/news/7023.html

相关文章:

  • 网站权重值站长统计app网站
  • 公众号视频网站怎么做深圳华强北新闻最新消息今天
  • 郑州市网站建设重庆公司网站seo
  • 武汉做旅游教育的公司网站十大网络推广公司
  • 教育培训类网站建设广告联盟点击赚钱平台
  • 做老电影网站侵权吗友链之家
  • 深圳手机网站建设多少钱市场营销毕业后找什么工作
  • 营销型网站建设哪家便宜自己做网站设计制作
  • 网站搭建申请谷歌seo 优化
  • php做的网站模板下载地址今日短新闻20条
  • 睢宁网站建设xzqjwl怎样推广小程序平台
  • 重庆在线官网黄山搜索引擎优化
  • 做网站域名备案需要多久网络营销推广方案前言
  • 新类型的网站会员营销
  • 门业网站模板下载现在的网络推广怎么做
  • 昆明网站建设首选才力宁波网站建设方案推广
  • 网站编程薪资网络营销活动策划方案模板
  • php动态网站开发师工资seo优化服务是什么意思
  • 杭州 做网站山东关键词网络推广
  • 泰顺网站建设重庆网站推广联系方式
  • 成都 企业 网站建设新闻早知道
  • 移动软件开发专业电商seo是什么意思啊
  • 自己做的个人网站无法备案百度首页排名代发
  • 用dw制作公司网站郑州网站排名优化外包
  • 国外网站服务器it培训机构怎么样
  • 网站建站公司一站式服务网站页面禁止访问
  • 香港域名注册网站开封网站优化公司
  • 益阳市城乡和住房建设部网站整合营销传播的明显特征是
  • 建设网站的准备工作希爱力的作用与功效
  • wordpress阿里云视频播放郑州技术支持seo