Day32| Leetcode 122. 买卖股票的最佳时机 II Leetcode 55. 跳跃游戏 Leetcode 45. 跳跃游戏 II

news/2024/7/24 7:21:28 标签: leetcode, 算法, 职场和发展

Leetcode 122. 买卖股票的最佳时机 II

题目链接 122 买卖股票的最佳时机 II

本题目设计的还是比较巧妙的,把最终的利润分为每天的利润就解决了(贪心),每天的利润就是前一天买进,后一天卖出,转化到代码上就是:p[i]-p[i-1],我们要取得最大利润,就需要最起码让每天的利润不为负数,所以我们只需要取每天大于0的利润加起来就能得到最终的最大利润了。下面上代码:

class Solution {
public:
    int maxProfit(vector<int>& prices) {
        int result = 0;
        for(int i=1;i<prices.size();i++){
           result += max(prices[i]-prices[i-1],0);
        }
        return result;
    }
};

Leetcode 55. 跳跃游戏

题目链接 55 跳跃游戏

本题目之前在dp专题做过两个差不多的,本题目比较简单,直接说贪心思路了,取最大范围,在i点时,最大范围能否到达最后一个点就可以判断了。

下面直接上代码:

class Solution {
public:
    bool canJump(vector<int>& nums) {
        int court = 0;
        if(nums.size() == 1){
            return true;
        }
        for(int i=0;i<=court;i++){//i 每次移动只能在 cover 的范围内移动,每移动一个元素,cover 得到该元素数值(新的覆盖范围)的补充,让 i 继续移动下去。
             court = max(court,i+nums[i]);
             if(court>=nums.size()-1){
                return true;
            }
        }
            return false;
    }
};

Leetcode 45. 跳跃游戏 II

题目链接 45 跳跃游戏 II

本题目还是比较有按难度的,首先说一下贪心思路:我们用每步最大的覆盖范围来取得最少的步数。如果移动下标达到了当前这一步的最大覆盖最远距离了,还没有到终点的话,那么就必须再走一步来增加覆盖范围,直到覆盖范围覆盖了终点。这时我们必须走的下一步必须是在第一步走的范围内点的能走的最大的覆盖范围,这里用代码表示的话就是:

 nextDistance = max(nums[i] + i, nextDistance)

当移动下标达到了当前覆盖的最远距离下标时

  • 如果当前覆盖最远距离下标不是是集合终点,步数就加一,还需要继续走。
  • 如果当前覆盖最远距离下标就是是集合终点,步数不用加一,因为不能再往后走了。

下面上代码:

class Solution {
public:
    int jump(vector<int>& nums) {
        if(nums.size()==1){
            return 0;
        }
            int result;
            int curDistance = 0;
            int nextDistance = 0;
            for(int i=0;i<nums.size();i++){
                nextDistance = max(nums[i]+i,nextDistance);//在遍历最大覆盖范围时,收集下一步最大覆盖范围
                if(i==curDistance){
                    result++;//步数
                    curDistance = nextDistance;//更新最大范围
                    if(nextDistance>=nums.size()-1){//覆盖范围到终点就结束
                        break;
                    }
                }
            }
          return result;  
    }
};

晚上学六级 end


http://www.niftyadmin.cn/n/5214426.html

相关文章

16.Python 多进程和多线程

进程是应用程序正在执行的实体&#xff0c;当程序执行时&#xff0c;也就创建了一个主线程。进程在创建和执行需要占用一定的资源&#xff0c;如内存、文件、I/O设备等。 线程是CPU使用的基本单元&#xff0c;由主线程创建&#xff0c;并使用这个进程的资源&#xff0c;因此线…

c语言:有关内存函数的模拟实现

memcpy函数&#xff1a; 功能&#xff1a; 复制任意类型的数据&#xff0c;存储到某一数组中。 代码模拟实现功能&#xff1a; #define _CRT_SECURE_NO_WARNINGS #include<stdio.h> #include<string.h> #include <stdio.h> #include<assert.h> memcpy…

c 语言中 unsigned int 类型的负数实际值大小

一 在c 语言中 unsigned int 类型的负数实际值大小 #include <stdio.h>int main() {int a 5;printf("a: %d\n", a);unsigned int b a - 10;printf("b: %d\n", b);printf("%d\n", b 4294967291); // unsigned int -5 4294967291retur…

Vue + Element UI 实现复制当前行数据功能及解决复制到新增页面组件值不更新的问题

文章目录 引言第一部分&#xff1a;复制当前行数据功能的实现1.1 环境准备1.2 创建表格并渲染数据1.3 解决复制的数据不更新问题 第二部分&#xff1a;拓展知识2.1 Vue的响应性原理2.2 Element UI的更多用法 结语 Vue Element UI 实现复制当前行数据功能及解决复制到新增页面组…

List转string 逗号分隔

List转string 逗号分隔 1、将list转化为逗号分割的字符串 String str String.join(",", list); String str StringUtils.json(list.toArray(), ",");   2、将逗号分隔的字符串转换为List List<String> list Arrays.asList(str.split("…

MySQL索引 Error1071

MySQL创建索引错误 Error 1071:Specified key was too long 目录 1. 起因2. 使用环境3. 查找问题的原因4. 解决方案5. 另外的解决方案6. 前缀索引 起因 事情的起因在一次生产环境部署启动服务&#xff0c;发现启动服务时间特别长&#xff0c;超过了5分钟的时间。于是&#…

在Python中matplotlib函数的plt.plot()函数的颜色参数设置,以及可以直接运行的程序代码!

文章目录 前言一、使用字符串颜色&#xff1a;二、使用十六进制颜色&#xff1a;三、使用RGB元组&#xff1a;四、使用颜色映射&#xff1a;总结 前言 在matplotlib中&#xff0c;plt.plot()函数可以接受颜色参数&#xff0c;可以设置为字符串颜色&#xff08;如red&#xff0…

带你用uniapp从零开发一个仿小米商场_5. 公共样式编写,

先前引入了公共样式,但公共样式文件里面还没有编写内容 在这里我将一一讲解公共样式内应该有什么样式,和为什么 首先给page添加高度和背景色,当然这个背景色可以在app.vue内添加 page{/* 设置page高,让每个页面的最小高度为整个视窗的高 */min-height: 100vh; /* 统一字体大小…