力扣hot100 最长递增子序列 线性DP 贪心 二分

这篇具有很好参考价值的文章主要介绍了力扣hot100 最长递增子序列 线性DP 贪心 二分。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

Problem: 300. 最长递增子序列
力扣hot100 最长递增子序列 线性DP 贪心 二分,力扣 hot100,leetcode,算法,职场和发展

💖 动态规划

思路

力扣hot100 最长递增子序列 线性DP 贪心 二分,力扣 hot100,leetcode,算法,职场和发展

复杂度

时间复杂度: O ( n 2 ) O(n^2) O(n2)

空间复杂度: O ( n ) O(n) O(n)文章来源地址https://www.toymoban.com/news/detail-809629.html

Code

class Solution {
	public int lengthOfLIS(int[] nums)
	{
		int n = nums.length;
		int[] f = new int[n + 1];// f[i] 表示以 nums[i] 结尾的最大上升子序列长度
		int ans = 0;
		for (int i = 0; i < n; i++)
		{
			f[i] = 1;//以自己为结尾,初始化长度为 1
			for (int j = 0; j < i; j++)
				if (nums[i] > nums[j])// 在 i 前边找到一个严格比自己小的元素,接上去(+1)
					f[i] = Math.max(f[i], f[j] + 1);
			ans = Math.max(ans, f[i]);//答案即是以任意元素结尾的最大上升子序列的最大值
		}
		return ans;
	}
}

💖 贪心 + 二分

思路

👨‍🏫 参考题解
力扣hot100 最长递增子序列 线性DP 贪心 二分,力扣 hot100,leetcode,算法,职场和发展

复杂度

时间复杂度: O ( n log ⁡ n ) O(n\log{n}) O(nlogn)

空间复杂度: O ( n ) O(n) O(n)

Code

class Solution {
	public int lengthOfLIS(int[] nums)
	{
		int n = nums.length;
		int[] tail = new int[n + 1];// tail[i] 表示子序列长度为 i 的最小元素值
		int ans = 0;
		for (int x : nums)
		{
			int l = 0;
			int r = ans;
//			找到 tail[i-1] < x < tail[i] 的位置,x就可以把 tail[i] 替换掉
//			换而言之,就是找到第一个  >  x 的 tail[i] 的 i (upperBound)
			while (l < r)
			{
				int m = l + r >> 1;
				if (tail[m] < x)
					l = m + 1;
				else
					r = m;
			}
			tail[l] = x;
			// ans == l 说明目前tail数组的元素都比当前的 num 要小 因此最长子序列的长度可以增加了 
			if (ans == l)
				ans++;
		}
		return ans;
	}
}

到了这里,关于力扣hot100 最长递增子序列 线性DP 贪心 二分的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 力扣300. 最长递增子序列

    思路: 假设 dp[i] 为前 i 个元素构成的最长递增子序列的个数,包含 nums[i]; 则 dp[i] 构成序列上一个元素 nums[j] 构成最长递增子序列 dp[j],则 dp[i] = dp[j] + 1; 如果动态取 j ∈ [0, i - 1],则选取其中最长递增子序列值中最大的,其值 + 1 来更新 dp[i] 的值;

    2024年02月04日
    浏览(41)
  • 最长递增子序列——力扣300

    2024年02月12日
    浏览(34)
  • 力扣--动态规划300.最长递增子序列

    一开始想到的方法非常低效,但好理解。   思路分析: 使用二维数组 dp 来记录递增子序列的长度信息,其中 dp[i][0] 表示以 nums[i] 结尾的最长递增子序列的长度, dp[i][1] 表示包含 nums[i] 的最长递增子序列的长度。 初始化 dp 数组,将以第一个元素结尾的递增子序列长度置为

    2024年01月24日
    浏览(49)
  • 力扣hot100 最长有效括号 动态规划

    Problem: 32. 最长有效括号 👨‍🏫 参考题解 ⏰ 时间复杂度: O ( n ) O(n) O ( n ) 🌎 空间复杂度: O ( n ) O(n) O ( n )

    2024年01月20日
    浏览(76)
  • 力扣hot100 杨辉三角 递归 DP

    Problem: 118. 杨辉三角 👨‍🏫 参考地址 时间复杂度: 添加时间复杂度, 示例: O ( n ) O(n) O ( n ) 空间复杂度: 添加空间复杂度, 示例: O ( n ) O(n) O ( n )

    2024年01月17日
    浏览(38)
  • 力扣300:最长递增子序列(Java动态规划+双指针)

    给你一个整数数组 nums ,找到其中最长严格递增子序列的长度。 子序列 是由数组派生而来的序列,删除(或不删除)数组中的元素而不改变其余元素的顺序。例如,[3,6,2,7] 是数组 [0,3,1,6,2,2,7] 的子序列。   示例 1: 输入:nums = [10,9,2,5,3,7,101,18] 输出:4 解释:最长递增子序

    2024年02月12日
    浏览(50)
  • 力扣hot100 打家劫舍 DP 滚动数组

    Problem: 198. 打家劫舍 👨‍🏫 参考地址 时间复杂度: O ( n ) O(n) O ( n ) 空间复杂度: O ( n ) O(n) O ( n ) 空间复杂度: O ( 1 ) O(1) O ( 1 )

    2024年01月19日
    浏览(41)
  • [100天算法】-最长递增子序列的个数(day 47)

    思路 代码 JavaScript Code C++ Code 复杂度分析 时间复杂度:$O(N^2)$。N 是数组  nums  的长度。 空间复杂度:$O(N)$。N 是辅助数组  length  和  count  的长度。

    2024年02月07日
    浏览(48)
  • [力扣 Hot100]Day8 无重复字符的最长子串

    给定一个字符串 s ,请你找出其中不含有重复字符的 最长子串 的长度。 出处 使用双指针构成一个滑动窗口,维护窗口内的字符不重复,逐步右移右指针,当右指针所指元素已经在窗口内时,左指针右移到和右指针所指元素重复的位置的右侧。 每次右移右指针会使窗口增大

    2024年01月22日
    浏览(42)
  • day55 最长递增子序列 最长连续递增子序列 最长重复子数组

    题目链接 300 最长递增子序列 题意 找到整数数组nums的最长严格递增子序列的长度(子序列并不改变原始的顺序,但是可以删除元素) 动态规划 动规五部曲 1)dp数组及下标i的含义 dp[i] 表示以nums[i]为结尾的最长递增子序列的长度 2)dp数组初始化 根据定义 长度至少是1  dp

    2024年04月11日
    浏览(61)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包