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

Day15(贪心算法)——LeetCode121.买卖股票的最佳时机55.跳跃游戏

1 LeetCode121.买卖股票的最佳时机(LeetCode121)

1.1 题目描述

  题目描述如下:
1
  示例如下:
2

1.2 问题分析及解决

  要求最大利润,即当天与之前天的价格之差最大值。因此我们可以遍历数组,记录下当前遇到的最小值,然后用当天的价格减最小值得到利润,选择遍历整个数组的最大利润即可:

class Solution {
public:int maxProfit(vector<int>& prices) {int minprice=INT_MAX;int maxprofit=INT_MIN;for(int i=0;i<prices.size();i++){//当前最便宜价格minprice=min(minprice,prices[i]);//当前最大利润maxprofit=max(maxprofit,prices[i]-minprice);}return maxprofit;   }
};

2 LeetCode55.跳跃游戏(LeetCode55)

2.1 题目描述

  题目描述如下:
3
  具体示例如下:
4

2.2 问题分析及解决

  贪心的思想,记录自己所能跳跃的最大值,每次只跳跃一步,每次跳跃一步时最大值减一,若小于0说明不能继续跳跃了,返回false,否则返回跳跃到下一个位置,更新自己所能跳跃的最大值(即剩余步数和当前位置能跳跃的长度的最大值),若能遍历到所有位置则返回true

class Solution {
public:bool canJump(vector<int>& nums) {int maxstep=nums[0];for(int i=1;i<nums.size();i++){//每次跳跃一步maxstep--;//如果没有步数向前则返回falseif(maxstep<0) return false;//否则更新自己能跳跃的最大步数maxstep=max(maxstep,nums[i]);}return true;}
};

相关文章:

  • 文献阅读(一)植物应对干旱的生理学反应 | The physiology of plant responses to drought
  • 机器学习基础理论 - 目标函数,损失函数,代价函数
  • C++入门(namespace/输入输出)
  • docker存储
  • 23.C语言指针相关知识点2
  • C++代码随想录刷题知识分享-----面试题链表相交
  • 传统农耕展陈如何突破?数字多媒体能否重构文化体验边界?
  • 阿里云ftp服务器登录要怎么做?如何访问ftp服务器?
  • 记录一下QA(from deepseek)
  • 开发vue项目所需要安装的依赖包
  • Redis ⑦-set | Zset
  • Leetcode刷题 | Day49_图论01
  • 《冰雪传奇点卡版》:详细打金攻略!
  • OpenGL学习笔记(法线贴图、视差贴图)
  • 基于 Spring Boot 瑞吉外卖系统开发(九)
  • 读论文《Deep learning-assited pulsed discharge plasma catalysis modeling》2023 ECM
  • 在QGraphicsView中精确地以鼠标为锚缩放图片
  • 【Light文献速览】湖南大学超表面高阶庞加莱球偏振检测时钟技术突破
  • EMC isilon/PowerScale 如何收集日志
  • 【神经网络与深度学习】五折交叉验证(5-Fold Cross-Validation)
  • 《中国奇谭》首部动画电影《浪浪山小妖怪》定档8月2日
  • 自称“最美”通缉犯出狱当主播?央广网:三观怎能跟着“五官”跑
  • “上报集团文化助力区域高质量发展赋能平台”揭牌
  • 贸促会答澎湃:5月22日将举办2025年贸易投资促进峰会
  • 下任美联储主席热门人选沃什:美联储犯下“系统性错误”,未能控制一代人以来最严重的通胀
  • 快捷公寓单间不足5平方米?公寓方:预订平台图片只是参考,已退房款