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

目录

​编辑

一,题目

二,题目接口

三,解题思路和代码


一,题目

给你一个整数数组 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();
    }
};
相关推荐
zzzkk2009几秒前
BambuStudio学习笔记:MTUtils
笔记·学习
算法与编程之美2 分钟前
冒泡排序
java·开发语言·数据结构·算法·排序算法
大宝剑1703 分钟前
blender学习25.3.11
学习·blender
Aphelios3804 分钟前
Java 学习记录:基础到进阶之路(一)
java·开发语言·学习·idea
卑微小文5 分钟前
企业级IP代理安全防护:数据泄露风险的5个关键防御点
前端·后端·算法
小逗比r6 分钟前
小白学习:提示工程(什么是prompt)
学习·prompt
虾球xz13 分钟前
游戏引擎学习第151天
学习·游戏引擎
爱学习的小王!19 分钟前
有关MyBatis的动态SQL
java·笔记·sql·学习·mybatis
一条晒干的咸魚29 分钟前
【C#学习笔记03】进制转换与反码、补码、原码
开发语言·笔记·学习·c#
Erik_LinX30 分钟前
算法日记36:leetcode095最长公共子序列(线性DP)
算法