最长上升子序列

news2024/11/17 21:31:56

基于最长上升子序列 LIS


求最长上升子序列有两种做法 求最长上升子序列有两种做法 求最长上升子序列有两种做法
一种是 n 2 复杂度的线性 d p 一种是n^2复杂度的线性dp 一种是n2复杂度的线性dp
另一种是 O ( n l o g n ) 复杂度的贪心 + 二分 另一种是O(nlogn)复杂度的贪心+二分 另一种是O(nlogn)复杂度的贪心+二分

贪心+二分做法

整体思路就是维护一个 l o w [ ] 数组,让数组长度等于当前最长子序列长度 整体思路就是维护一个low[]数组,让数组长度等于当前最长子序列长度 整体思路就是维护一个low[]数组,让数组长度等于当前最长子序列长度
用 a n s 表示当前 l o w 数组长度 用ans表示当前low数组长度 ans表示当前low数组长度
当当前值大于 l o w [ a n s ] 时 l o w [ + + a n s ] = 当前值 当当前值大于low[ans]时 low[++ans] = 当前值 当当前值大于low[ans]low[++ans]=当前值
当当前值小于 l o w [ a n s ] 时利用二分找到在 l o w 数组中当前值所在的位置然后替换为当前值 当当前值小于low[ans]时 利用二分找到在low数组中当前值所在的位置然后替换为当前值 当当前值小于low[ans]时利用二分找到在low数组中当前值所在的位置然后替换为当前值
l o w [ f i n d ( 当前值 ) ] = 当前值 low[find(当前值)]=当前值 low[find(当前值)]=当前值
目的就是保证 l o w 数组是当前最长的上升子序列 目的就是保证low数组是当前最长的上升子序列 目的就是保证low数组是当前最长的上升子序列

代码


#include<bits/stdc++.h>

using namespace std;

const int N = 1e3 + 10;

typedef long long ll;

ll low[N], arr[N];

int n;

int find(ll x, int len)
{
    int l = 1;
    int r = len;
    while(l < r)
    {
        int mid = l + r >> 1;
        
        if(low[mid] >= x)
        {
            r = mid;
        }
        else l = mid + 1;
    }
    
    return l;
}

int main()
{
    cin >> n;
    
    for(int i = 1; i <= n; i ++)
    {
        scanf("%lld", &arr[i]);
    }
    
    int ans = 1;
    
    low[ans] = arr[1]; //一开始第一个数就是最长上升子序列
    
    for(int i = 2; i <= n; i ++)
    {
        if(arr[i] > low[ans])
        {
            low[++ans] = arr[i];
        }
        else
        {
            low[find(arr[i],ans)] = arr[i];
        }
    }
    
    cout << ans << endl;
    
    return 0;
}


线性dp做法

图解


#include<bits/stdc++.h>

using namespace std;

const int N = 1e4 + 10;

typedef long long ll;

ll arr[N];

int f[N];

int n;

int main()
{
    cin >> n;
    
    for(int i = 1; i <= n; i ++)
    {
        scanf("%lld", &arr[i]);
    }
    
    int res = 0;
    
    for(int i = 1; i <= n; i ++)
    {
        f[i] = 1; //初始化 每个数结尾最开始都是长度为1的LIS
        
        for(int j = 1; j < i; j ++)
        {
            if(arr[i] > arr[j])
            f[i] = max(f[i], f[j] +1);
        }
    }
    
    for(int i = 1; i <= n; i ++)
    {
        res = max(res, f[i]);
    }
    
    cout << res << endl;
    
    return 0;
}

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

看BP英文文献生词记录

看BP英文文献生词记录 总的来说&#xff0c;该论文是在讲CAT和SAR的后向后向投影之间的联系与区别 acoustic imaging 原声成像 polychromatic 美 [pɒlɪkroʊ’mtɪk] 英 [pɒlɪkrəʊ’mtɪk] adj.多色的 illumination 美 [ɪˌlumɪˈneɪʃ(ə)n] 英 [ɪˌluːmɪˈne…

我国牛血清行业现状:FBS是最常用血清添加剂 但目前市场亟需规范化

根据观研报告网发布的《中国牛血清行业现状深度研究与投资前景分析报告&#xff08;2022-2029年&#xff09;》显示&#xff0c;牛血清是血清的一种&#xff0c;是一种浅黄色澄清、无溶血、无异物稍粘稠液体&#xff0c;内含有各种血浆蛋白、多肽、脂肪、碳水化合物、生长因子、…

15. 使用stunnel加密tcp数据传输

主题&#xff1a;使用stunnel加密隧道对tcp数据进行加密传输。 开发环境&#xff1a; 客户端&#xff1a; stunnel5 Win10服务端&#xff1a; stunnel5 Ununtu18.04(虚拟机) Qt5.9.9对于stunnel&#xff0c;前面博客有所提及&#xff0c;有兴趣可以自行观看&#xff0c;…

javaSE(包、封装、static用法、代码块)

1.包 &#xff08;文件夹&#xff09; 为了更好的管理类&#xff0c;把多个类收集在一起成为一组&#xff0c;称为软件包。 在Java中也引入了包&#xff0c;包是对类、接口等的封装机制的体现&#xff0c;是一种对类或者接口等的很好的组织方式&#xff0c;比如&#xff1a;一…

【细读JS忍者秘籍】深入生成器函数的底层原理

深入生成器函数的底层原理 分析执行上下文 生成器函数本质上还是一个_函数_&#xff0c;所以它的执行离不开 执行上下文 function* generator() {console.log("status1");yield "hello";console.log("status2");yield "world";}let…

Web入门开发【七】- 运行原理

欢迎来到霍大侠的小院&#xff0c;我们来学习Web入门开发的系列课程。 首先我们来了解下这个课程能学到什么&#xff1f; 1、你将可以掌握Web网站的开发全过程。 2、了解基础的HTML&#xff0c;CSS&#xff0c;JavaScript语言。 3、开发自己的第一个网站。 4、认识很多对编…

学到羊之Kafka

1 kafka 是啥 Kafka 是一款开源的消息引擎系统&#xff0c;用来实现解耦的异步式数据传递。即系统 A 发消息给到 消息引擎系统&#xff0c;系统 B 通过消息引擎系统读取 A 发送的消息&#xff0c;在大数据场景下&#xff0c;能达到削峰填谷的效果。 2 Kafka 术语 Kafka 中的分…

性能测试要学习哪些知识?全在这里了

基础&#xff1a;   完整的性能测试流程     需求-计划-方案-环境搭建-用例设计-数据准备-场景设计-脚本开发-脚本执行-结果分析-问题反馈-性能调优-结果报告   性能指标     TPS&#xff0c;QPS&#xff0c;RPS&#xff0c;HPS&#xff0c;RT&#xff0c;VU&#…

【Pandas入门教程】在Pandas中如何创建plots

在Pandas中如何创建plots 来源&#xff1a;Pandas官网&#xff1a;https://pandas.pydata.org/docs/getting_started/intro_tutorials/index.html 文章目录在Pandas中如何创建plots导包数据集准备【小结】导包 import pandas as pd import matplotlib.pyplot as plt数据集准备…

力扣(LeetCode)200. 岛屿数量(C++)

深度优先遍历 求连通块数量。可以遍历所有格子&#xff0c;当格子是岛屿&#xff0c;对岛屿深度优先遍历&#xff0c;找到整个岛&#xff0c;并且将遍历的岛屿标记&#xff0c;以免重复遍历&#xff0c;或递归死循环。标记可以使用状态数组&#xff0c;也可以修改格子的值。本…

SQL注入渗透与攻防(十)之加解密注入和堆叠注入

目录 SQL注入之加解密注入 案列演示 SQL注入之堆叠注入 案列演示 SQL注入之加解密注入 Base64是网络上最常见的用于传输8Bit字节码的编码方式之一&#xff0c;Base64就是一种基于64个可打印字符来表示二进制数据的方法。 案列演示 这里我们拿sql-libs的第二十一关来进行演…

学习TrustZone可以参考的资料

最近看到了一篇学习资料分享的&#xff0c;感觉可以转过来做个记录&#xff0c;除去前辈分享的资料以外&#xff0c;我还觉得ATF的源码里面的DOC目录下的资料也是很不错的&#xff0c;起码可以让你对BL31有个比较不错的认识。当然那个有点太细节了。 最近看PSA安全技术交流微信…

30多岁想转行,零基础学编程,来得及吗?

“30多岁想转行&#xff0c;零基础学编程&#xff0c;来得及吗&#xff1f;能找到好工作吗&#xff1f;”这类问题&#xff0c;总是反复出现。尤其是最近我受《自学是门手艺》鼓舞&#xff0c;也借着参与 xue.cn 的契机想要把 python 学的全面而完整&#xff0c;也总有朋友找我…

从工地打工,到狂揽10个大厂offer、副业赚100万:培训班出来的程序员是怎么做到的?

七年前我 985 毕业却沦落到工地打工&#xff0c;七年后我已经收到了 10 个大厂 offer 。 你好&#xff0c;我是吴师兄&#xff0c;一位曾经的学霸毕业只能去工地&#xff0c;而如今大厂 offer 拿到手软&#xff0c;Github 全球 TOP100 算法仓库创作者&#xff0c;公众号五分钟…

eclipse和sts安装lombok

eclipse和sts安装lombok 说明 sts 是 eclipse集成springboot的开发环境 所以 sts 和 eclipse 安装 lombok 步骤基本一样 参考网址: https://blog.csdn.net/qq_39826207/article/details/119007580?ops_request_misc%257B%2522request%255Fid%2522%253A%252216708973141680…

算法day57|647,516

目录 647. 回文子串 516.最长回文子序列 动态规划总结篇 647. 回文子串 dp数组的定义 dp[i][j]代表的是区间[i,j]的字串是否为回文字符&#xff0c;如果dp[i][j]为true,否则为false 递推公式 如果s[i]和s[j]相等的话 1.ij 为同一个字符&#xff0c;dp[i][j] True 2 i与j相差1…

Kafka大厂高频面试题:在保证高性能、高吞吐的同时保证高可用性

Kafka的消息传输保障机制非常直观。当producer向broker发送消息时&#xff0c;一旦这条消息被commit&#xff0c;由于副本机制&#xff08;replication&#xff09;的存在&#xff0c;它就不会丢失。但是如果producer发送数据给broker后&#xff0c;遇到的网络问题而造成通信中…

火山引擎 DataTester 上线“流程画布”功能,支持组合型 A/B 实验分析

更多技术交流、求职机会&#xff0c;欢迎关注字节跳动数据平台微信公众号&#xff0c;回复【1】进入官方交流群 在精细化运营的时代&#xff0c;运营活动同样需要有精细化的策略&#xff0c;例如在年末大促活动中&#xff0c;设计 APP 弹窗提醒、满减、会员领券时&#xff0c;我…

C#语言实例源码系列-实现批量更改文件名称大小写或扩展名

专栏分享点击跳转>Unity3D特效百例点击跳转>案例项目实战源码点击跳转>游戏脚本-辅助自动化点击跳转>Android控件全解手册 &#x1f449;关于作者 众所周知&#xff0c;人生是一个漫长的流程&#xff0c;不断克服困难&#xff0c;不断反思前进的过程。在这个过程中…

DeepLearning_Note

这里写目录标题深度学习框架深度学习开发万能公式模型的网络设计和开发&#xff1a;激活函数&#xff1a;几个数据参数&#xff1a;神经网络的输出零碎知识点&#xff1a;深度学习框架 深度学习开发万能公式 ① 问题定义 ② Paddle.vision.datasets&#xff08;内置数据集&am…