[Algorithm][贪心][最长递增子序列][递增的三元子序列][最长连续递增序列][买卖股票的最佳时机][买卖股票的最佳时机Ⅱ]详细讲解


1.最长递增子序列

1.题目链接


2.算法原理详解

  • 基本思想

    • 动态规划
    • 二分查找
  • 动态规划思路

    • 状态表示:以i位置的元素为结尾的所有的子序列中,最长递增子序列的长度
    • 状态转移方程dp[i] = max(dp[j] + 1) (j < i && nums[j] < nums[i])
    • 该思路中,并不关心该序列长什么样子,只在乎”最后一个元素”是谁
  • 贪心优化

    • 存什么;所有长度为x的递增子序列中,最后一个元素的最小值
    • 存哪里:所有大于等于nums[i]的最小值的位置
      请添加图片描述
  • 利用二分优化:时间复杂度: O ( N ) O(N) O(N) -> O ( l o g N ) O(log_N) O(logN)
    请添加图片描述


3.代码实现

int lengthOfLIS(vector<int>& nums) 
{
    int n = nums.size();
    vector<int> ret;
    ret.push_back(nums[0]);

    for(int i = 1; i < n; i++)
    {
        if(nums[i] > ret.back())
        {
            ret.push_back(nums[i]);
        }
        else
        {
            // 二分插入位置
            int left = 0, right = ret.size() - 1;
            while(left < right)
            {
                int mid = left + (right - left) / 2;
                if(ret[mid] < nums[i])
                {
                    left = mid + 1;
                }
                else
                {
                    right = mid;
                }
            }

            ret[left] = nums[i];
        }
    }

    return ret.size();
}

2.递增的三元子序列

1.题目链接


2.算法原理详解

  • 本题的贪心策略和最长递增子序列一样
    • 但是本题只需两个变量即可完成贪心,无需数组
      请添加图片描述

3.题目链接

bool increasingTriplet(vector<int>& nums) 
{
    int a = nums[0], b = INT_MAX;
    for(int i = 1; i < nums.size(); i++)
    {
        if(nums[i] > b)
        {
            return true;
        }
        else if(nums[i] > a)
        {
            b = nums[i];
        }
        else
        {
            a = nums[i];
        }
    }

    return false;
}

3.最长连续递增序列

1.题目链接


2.算法原理详解

  • 思路;贪心 + 双指针

3.代码实现

int findLengthOfLCIS(vector<int>& nums) 
{
    int n = nums.size(), ret = 0;
    for(int i = 0; i < n; )
    {
        int j = i + 1;
        while(j < n && nums[j - 1] < nums[j])
        {
            j++;
        }

        ret = max(ret, j - i);
        i = j; // 贪心
    }

    return ret;
}

4.买卖股票的最佳时机

1.题目链接


2.算法原理详解

  • 思路:贪心 + 一个变量标记“前缀最小值”

3.代码实现

int maxProfit(vector<int>& prices) 
{
    int ret = 0, prevMin = INT_MAX;
    for(int i = 0; i < prices.size(); i++)
    {
        if(prices[i] > prevMin)
        {
            ret = max(ret, prices[i] - prevMin);
        }

        prevMin = min(prices[i], prevMin); // 贪心
    }

    return ret;
}

5.买卖股票的最佳时机 II

1.题目链接


2.算法原理详解

  • 贪心:只要能获得正收益,就交易

  • 实现一:双指针
    请添加图片描述

  • 实现二:拆分交易,把交易拆成一天一天
    请添加图片描述


3.代码实现

// v1.0 双指针
int maxProfit(vector<int>& p) 
{
    int ret = 0, n = p.size();
    for(int i = 0; i < n; i++)
    {
        int j = i;
        while(j + 1 < n && p[j + 1] > p[j])
        {
            j++;
        }

        ret += p[j] - p[i];
        i = j;
    }

    return ret;
}
---------------------------------------------------------
// v2.0 拆分成一天一天
int maxProfit(vector<int>& p) 
{
    int ret = 0;
    for(int i = 1; i < p.size(); i++)
    {
        if(p[i - 1] < p[i])
        {
            ret += p[i] - p[i - 1];
        }
    }

    return ret;
}

相关推荐

最近更新

  1. TCP协议是安全的吗?

    2024-06-15 08:46:02       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-06-15 08:46:02       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-06-15 08:46:02       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-06-15 08:46:02       18 阅读

热门阅读

  1. Pod中使用自定义服务账号调用自定义资源

    2024-06-15 08:46:02       9 阅读
  2. 使用dockerfile能力构建制品并打包容器

    2024-06-15 08:46:02       6 阅读
  3. C# 泛型分析

    2024-06-15 08:46:02       8 阅读
  4. 找工作小项目:day15-macOS支持、完善逻辑

    2024-06-15 08:46:02       5 阅读
  5. 自动化机械臂喷涂生产线方案五

    2024-06-15 08:46:02       7 阅读
  6. AWD攻防比赛流程手册

    2024-06-15 08:46:02       6 阅读
  7. 公链常用的共识算法

    2024-06-15 08:46:02       8 阅读
  8. 探索 Spring Boot 集成缓存功能的最佳实践

    2024-06-15 08:46:02       8 阅读
  9. 第十三章:huggingface的resume训练源码内容

    2024-06-15 08:46:02       7 阅读
  10. 用python写一个企业知识库算法

    2024-06-15 08:46:02       8 阅读
  11. ADBMS1818驱动程序解析

    2024-06-15 08:46:02       7 阅读