贪心算法学习——最长单调递增子序列

目录

​编辑

一,题目

二,题目接口

三,解题思路和代码


一,题目

给你一个整数数组 nums ,找到其中最长严格递增子序列的长度。

子序列 是由数组派生而来的序列,删除(或不删除)数组中的元素而不改变其余元素的顺序。例如,[3,6,2,7] 是数组 [0,3,1,6,2,2,7] 的子序列。

示例 1:

复制代码
输入:nums = [10,9,2,5,3,7,101,18]
输出:4
解释:最长递增子序列是 [2,3,7,101],因此长度为 4 。

示例 2:

复制代码
输入:nums = [0,1,0,3,2,3]
输出:4

示例 3:

复制代码
输入:nums = [7,7,7,7,7,7,7]
输出:1

二,题目接口

cpp 复制代码
class Solution {
public:
    int lengthOfLIS(vector<int>& nums) {

    }
};

三,解题思路和代码

这道单调递增子序列的算法题的解法有很多,比如动态规划,记忆化搜索等等。但是使用动态规划和记忆化搜索的时间复杂度都比较高大概都是O(n^2)。但是使用贪心算法的思想来解答这道题的话能让时间复杂度下降到O(n*log2N)。现在就来说一下该如何实现这个算法。

步骤:

**1,**首先我们得要创建一个vector<int>类型的数组ret。这个数组是用来存储子序列的。

**2,**对nums数组进行遍历对于每个数组元素nums[i]会有两种不同的情况:

1.大于ret.back(),这个时候直接将这个nums[i]插入到ret的最后面。

2.小于ret.back(),这个时候便要采用二分查找法在ret中找到一个合适的位置放入 nums[i].

**3.**遍历结束后便可以返回ret.size()。

代码如下:

cpp 复制代码
class Solution {
public:
    int lengthOfLIS(vector<int>& nums) {
    
         vector<int>ret;
         ret.push_back(nums[0]);
        for(int i = 1;i<nums.size();i++)
        {
           if(nums[i]>ret.back())
           {
               ret.push_back(nums[i]);
           }

           else
           {
               int left = 0;
               int right = ret.size()-1;

              while(left<right)
              {
               int mid = (right+left)/2;
                if(nums[i]>ret[mid])
               {
                   left = mid+1;
               }
               else
               {
                   right = mid;
               }

              }

             ret[right] = nums[i];

           }
        }
         
         return ret.size();
    }
};
相关推荐
HalvmånEver2 小时前
MySQL的索引
android·linux·数据库·学习·mysql
Jasmine_llq3 小时前
《B3867 [GESP202309 三级] 小杨的储蓄》
算法·循环遍历·数组累加(模拟)·索引定位·顺序输出
啦啦啦_99993 小时前
案例之 逻辑回归_电信用户流失预测
算法·机器学习·逻辑回归
金色光环3 小时前
【DSP学习】DSP28335 点亮LED
嵌入式硬件·学习·dsp开发
风筝在晴天搁浅3 小时前
快手/字节 CodeTop LeetCode 415.字符串相加
算法·leetcode
我是发哥哈3 小时前
跨AI模型生成视频的五大维度对比:选型避坑指南
大数据·人工智能·学习·机器学习·chatgpt·音视频
小黄人软件3 小时前
C++读写编辑CSV文件示例源码 用于数据导入导出,比Excel好使
开发语言·c++·excel
郭涤生3 小时前
C++各个版本的性能和安全性总结
开发语言·c++
DragonnAi4 小时前
猫咪如厕检测与分类识别系统系列【十四】 项目结构重新整理-即将开源完整算法
算法·开源
机器视觉_Explorer4 小时前
【halcon】编程技巧:鼠标擦除
图像处理·人工智能·深度学习·算法·视觉检测