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

算法笔记|Day23贪心算法

算法笔记|Day23贪心算法

  • ☆☆☆☆☆leetcode 455.分发饼干
    • 题目分析
    • 代码
  • ☆☆☆☆☆leetcode 376. 摆动序列
    • 题目分析
    • 代码
  • ☆☆☆☆☆leetcode 53. 最大子序和
    • 题目分析
    • 代码

☆☆☆☆☆leetcode 455.分发饼干

题目链接:leetcode 455.分发饼干

题目分析

优先考虑饼干,先喂饱小胃口:若饼干不足以喂孩子,则换下一块饼干;若能喂,则count加一,换下一块饼干喂下一个孩子。

代码

class Solution {public int findContentChildren(int[] kid, int[] biscuit) {Arrays.sort(kid);Arrays.sort(biscuit);int count=0;int i=0;for(int j=0;i<kid.length&&j<biscuit.length;j++){if(biscuit[j]>=kid[i]){count++;i++;}}return count;}
}

☆☆☆☆☆leetcode 376. 摆动序列

题目链接:leetcode 376. 摆动序列

题目分析

此题需要计算前一个差值preDiff和当前差值curDiff,若一正一负(preDiff>0&&curDiff<0||preDiff<0&&curDiff>0)则出现摆动count加一。在此基础上,还应考虑以下三种情况:①上下坡中有平坡,需要在一侧补充等于0的情况,改为preDiff>=0和preDiff<=0;②数组首尾两端,考虑只有两个元素的情况,结果应为2,可以假设前一个preDiff为0,过程中加一,结尾自动加一,也就是count初始值为1,遍历是不考虑最后一个元素;③单调坡中有平坡只需要在这个坡度摆动变化的时候,更新preDiff就行。

代码

class Solution {public int wiggleMaxLength(int[] nums) {int count=1;int preDiff=0,curDiff=0;for(int i=0;i<nums.length-1;i++){curDiff=nums[i+1]-nums[i];if(preDiff>=0&&curDiff<0||preDiff<=0&&curDiff>0){count++;preDiff=curDiff;}}return count;}
}

☆☆☆☆☆leetcode 53. 最大子序和

题目链接:leetcode 53. 最大子序和

题目分析

依次遍历每个元素,并求得连续元素和,若比当前res值大,则赋给res。若当前连续元素和小于0,则重新计算元素和,sum赋值为0。

代码

class Solution {public int maxSubArray(int[] nums) {int res=Integer.MIN_VALUE,sum=0;for(int i=0;i<nums.length;i++){sum+=nums[i];res=sum>res?sum:res;if(sum<0)sum=0;}return res;}
}
http://www.lryc.cn/news/426350.html

相关文章:

  • [星瞳科技]OpenMV使用时有哪些常见错误和解决办法?
  • 深度学习入门(二):PyTorch使用-张量的类型转换,拼接操作,索引操作,形状操作
  • 使用C#禁止Windows系统插入U盘(除鼠标键盘以外的USB设备)
  • 18. 基于ES实战海量数据检索
  • SpringBoot和Redis的交互数据操作以及Redis的持久化/删除策略和缓存问题
  • Butterworth filter的运行原理
  • 掌握SQL的威力:批量更新与删除的艺术
  • 《新一代数据可视化分析工具应用指南》正式开放下载
  • 数据结构与算法——BFS(广度优先搜索)
  • 登录 k8s-Dashboard 显示 Your connection is not private
  • 【Bifrost】ubuntu24.04 远程构建及clion设置编码风格google
  • 批量查询全国快递单号:高效追踪物流信息
  • DVWA | CSRF(LowMedium)攻击的渗透实践
  • Tmagic-editor低代码底层拖拽库Moveable示例学习
  • 公开测评:文件防泄密系统哪家好|4款文件防泄密软件推荐
  • 【wiki知识库】09.欢迎页面添加(统计浏览量)Vue修改
  • ui自动化难点
  • 静态路由与默认路由和实验以及ARP工作原理
  • 美国洛杉矶大带宽服务器的运维与监控
  • AtCoder Beginner Contest 367 A~D
  • oracle 保留两位小数
  • Aop切面技术之存储用户信息
  • FreeBSD 针对OpenSSH 高危漏洞发布紧急补丁
  • 【C语言小项目】五子棋游戏
  • 基于Java语言的能源管理系统-水电气热油数据采集系统
  • 人工智能在肿瘤亚型分类领域的研究进展|顶刊速递·24-08-13
  • Taro+Vue 创建微信小程序
  • 智能安全守护,寺庙安全用电解决方案
  • 加热系统加入达温即停和保温功能
  • C++_2_ inline内联函数 宏函数(2/3)