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

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

1.1 题目描述

题目描述如下:

示例如下:

1.2 问题分析及解决

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

cpp 复制代码
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 题目描述

题目描述如下:

具体示例如下:

2.2 问题分析及解决

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

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

        }
        return true;
    }
};
相关推荐
加成BUFF4 分钟前
C++入门讲解3:数组与指针全面详解
开发语言·c++·算法·指针·数组
代码游侠13 分钟前
应用——管道与文件描述符
linux·服务器·c语言·学习·算法
一招定胜负16 分钟前
决策树开篇
算法·决策树·机器学习
GoWjw16 分钟前
C语言高级特性
c语言·开发语言·算法
carver w20 分钟前
说人话版 K-means 解析
算法·机器学习·kmeans
程序猿阿伟24 分钟前
《游戏平衡的高阶解法:强化学习主导的参数迭代策略》
游戏
小O的算法实验室26 分钟前
2026年SEVC SCI2区,基于差分向量内学习策略的自适应指数交叉差分进化算法,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
天若有情67332 分钟前
我发明的PROTO_V4协议:一个让数据“穿上迷彩服”的发明(整数传输协议)
网络·c++·后端·安全·密码学·密码·数据
加油=^_^=34 分钟前
【C++11】特殊类设计 | 类型转换
c++·单例模式·类型转换
gloomyfish34 分钟前
【最新技术】多模态零样本工业缺陷检测概述
人工智能·算法·计算机视觉