关于最长上升子序列的动态规划问题的优化算法(二分搜索)

最长递增子序列

暴力解法:

        思路:使用动态规划的思想,判断当前元素之前的所有元素,如果比当前元素小,则修改当前元素的最长递增子序列(需判断是否需要修改)。

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

import java.util.Arrays;class Solution {public int lengthOfLIS(int[] nums) {int dp[] = new int[nums.length];Arrays.fill(dp, 1);for (int i = 0; i < nums.length; i++) {for (int j = 0; j < i; j++) {if (nums[i] > nums[j]) {dp[i] = Math.max(dp[i], dp[j] + 1);}}}Arrays.sort(dp);return dp[nums.length - 1];}
}

 题目所给nums长度比较小,使用暴力解法可以ac。

俄罗斯套娃问题

此题也是一道求最长上升子序列的问题,不过值范围较大,暴力解法会TLE。

那么需要我们对最长上升子序列问题进行优化。

此处以最长上升子序列问题为例进行优化。

 

思路:我们的目的是寻找最长递增子序列,通过观察可以发现在相同长度下,两个元素较小的那个元素更有扩展为更长的子序列的潜力。

例如[3,1,2,4] ,在子序列长度同为1的情况下,如果选择了3,那么后面比3大的元素一定比1大,所以选1比选3有更大的机会生成一个最长递增子序列。 

有了上面的铺垫,我们可以创建一个数组,在每个长度范围内都会存在一个大于子序列所有元素的最大值,用其来记录长度为len的递增子序列的最大值。遍历数组,每次替换掉长度序列里的刚好大于当前元素的最大值。最后返回最长的子序列长度即可。

(建议可以自己模拟遍历一遍)

这里是基于动态规划的思想,但是没有用到动态规划,使用了二分搜索优化。

时间复杂度:O(nlog(n))

class Solution {public static int lengthOfLIS(int[] nums) {int len = 0;//记录p的长度int p[] = new int[2510];for (int i = 0; i < nums.length; i++) {int l = 0, r = len;while (l < r) {int mid = (l + r + 1) / 2;if (p[mid] < nums[i]) {l = mid;} else {r = mid - 1;}}p[r + 1] = nums[i];len = Math.max(len, r + 1);}return len;}
}

两种时间复杂度对比

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/256391.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

“分割“安卓用户,对标iOS,鸿蒙崛起~

近期关于**“华为于明年推出不兼容安卓的鸿蒙版本”**的消息传出&#xff0c;引起了业界的热议关注。自从2019年8月&#xff0c;美国制裁下&#xff0c;华为不再能够获得谷歌安卓操作系统相关付费服务&#xff0c;如此情况下&#xff0c;华为“备胎”鸿蒙操作系统一夜转正。 华…

虚拟化之指令的Trap和仿真

有时,虚拟机监控程序需要在虚拟机(VM)中模拟操作。例如,VM内的软件可能尝试配置与功耗管理或缓存一致性相关的低级处理器控件。通常,您不希望将VM直接访问这些控件,因为它们可能被用于突破隔离,或影响系统中的其他VM。 trap在执行给定操作(例如读取寄存器)时引发异常…

UEC++ 探索虚幻5笔记 day11

虚幻5.2.1探索 项目目录探索 C工程一定不能是中文路径&#xff0c;中文项目名&#xff0c;最好全部不要用中文&#xff0c;蓝图项目可以是中文浅浅创建一个空项目&#xff0c;讲解一下之前UE4没有讲解的项目目录文件的分布组成 .vs&#xff1a;文件夹一般是项目编译缓存文件夹…

探索SpringBoot发展历程

✅作者简介&#xff1a;大家好&#xff0c;我是Leo&#xff0c;热爱Java后端开发者&#xff0c;一个想要与大家共同进步的男人&#x1f609;&#x1f609; &#x1f34e;个人主页&#xff1a;Leo的博客 &#x1f49e;当前专栏&#xff1a; 循序渐进学SpringBoot ✨特色专栏&…

matplot函数调整子图大小测试

调整subplot()函数的子图间距 import numpy as np import matplotlib.pyplot as plt for i in range(1,7):figsize 10,6plt.subplot(2,3,i)plt.text(0.5,0.5,str((2,3,i)),fontsize18,hacenter) **plt.subplots_adjust(hspace3.3, wspace0.3)** plt.show()import numpy as np…

AV1编码技术分享指南 ‍

&#x1f337;&#x1f341; 博主猫头虎 带您 Go to New World.✨&#x1f341; &#x1f984; 博客首页——猫头虎的博客&#x1f390; &#x1f433;《面试题大全专栏》 文章图文并茂&#x1f995;生动形象&#x1f996;简单易学&#xff01;欢迎大家来踩踩~&#x1f33a; &a…

【STM32】TIM定时器输入捕获

1 输入捕获 1.1 输入捕获简介 IC&#xff08;Input Capture&#xff09;输入捕获 输入捕获模式下&#xff0c;当通道输入引脚出现指定电平跳变时&#xff08;上升沿/下降沿&#xff09;&#xff0c;当前CNT的值将被锁存到CCR中&#xff08;把CNT的值读出来&#xff0c;写入到…

动态设置当前按钮是否可以点击

当审核状态为通过时不可以点击审核按钮 <vxe-columnfixed"right"align"center"width"100"title"操作"><template slot-scope"scope"><el-button v-if"hasPermission(basic:archivalInfo:edit)":di…

【学习记录】从0开始的Linux学习之旅——字符型设备驱动及应用

一、概述 Linux操作系统通常是基于Linux内核&#xff0c;并结合GNU项目中的工具和应用程序而成。Linux操作系统支持多用户、多任务和多线程&#xff0c;具有强大的网络功能和良好的兼容性。基于前面应用与驱动的开发学习&#xff0c;本文主要讲述如何在linux系统上把应用与驱动…

Vulnhub项目:EMPIRE: LUPINONE

一、靶机地址 靶机地址&#xff1a;Empire: LupinOne ~ VulnHub 靶机描述&#xff1a; 来&#xff0c;看一看&#xff0c;同样的配方&#xff0c;不同的设计&#xff0c;难度为中等&#xff0c;迷路了就成困难了&#xff0c;不得不说&#xff0c;还真是&#xff01; 几次陷入…

家用保险柜什么牌子好?

家用保险柜的品牌有很多&#xff0c;其中比较知名的有虎牌、得力、永发、思锐、迪堡、艾谱、全能、杰宝-大王、金虎、花都、飞云、威盾斯等等。这些品牌都有各自的特点和优势&#xff0c;例如虎牌品牌是来自于河北&#xff0c;每年生产60多台&#xff0c;质量可靠&#xff1b;得…

【从零认识ECS云服务器 | 快速上线个人网站】阿里云手动搭建WordPress网站

第一步&#xff1a;部署 LAMP/LNMP 环境&#xff0c;需要在ECS实例中安装操作系统&#xff08;Linux&#xff0c;本例中使用的操作系统版本为CentOS 7.9 64位&#xff09;、Web服务器软件&#xff08;Apache/Nginx&#xff09;、数据库软件&#xff08;MySQL&#xff09;、网站…