尧图网站建设 尧图网络
  • 首页
  • 关于我们
  • 服务项目
  • 案例展示
  • 建站流程
  • 资讯中心
  • 联系我们
首页/资讯中心/详情

最长严格/非严格递增子序列 (LIS)

最长严格/非严格递增子序列 (LIS)
📅 发布时间:2026/6/19 20:33:37

最长严格/非严格递增子序列 (LIS)

一维

注意子序列是不连续的。使用二分搜索,以 \(\mathcal O(N\log N)\) 复杂度通过,另也有 \(\mathcal O(N^2)\) 的 \(\tt dp\) 解法。\(\sf dis\) \(\rm dis\)

vector<int> val; // 堆数
for (int i = 1, x; i <= n; i++) {cin >> x;int it = upper_bound(val.begin(), val.end(), x) - val.begin(); // low/upp: 严格/非严格递增if (it >= val.size()) { // 新增一堆val.push_back(x);} else { // 更新对应位置元素val[it] = x;}
}
cout << val.size() << endl;

二维+输出方案

vector<array<int, 3>> in(n + 1);
for (int i = 1; i <= n; i++) {cin >> in[i][0] >> in[i][1];in[i][2] = i;
}
sort(in.begin() + 1, in.end(), [&](auto x, auto y) {if (x[0] != y[0]) return x[0] < y[0];return x[1] > y[1];
});vector<int> val{0}, idx{0}, pre(n + 1);
for (int i = 1; i <= n; i++) {auto [x, y, z] = in[i];int it = lower_bound(val.begin(), val.end(), y) - val.begin(); // low/upp: 严格/非严格递增if (it >= val.size()) { // 新增一堆pre[z] = idx.back();val.push_back(y);idx.push_back(z);} else { // 更新对应位置元素pre[z] = idx[it - 1];val[it] = y;idx[it] = z;}
}vector<int> ans;
for (int i = idx.back(); i != 0; i = pre[i]) {ans.push_back(i);
}
reverse(ans.begin(), ans.end());
cout << ans.size() << "\n";
for (auto it : ans) {cout << it << " ";
}

相关新闻

  • 博弈1
  • 1024程序员节福利!参与互动,5分钟赢好礼!
  • 马拉车

最新新闻

  • 2026年湖北百合种植基地推荐排行榜:百合技术/百合回收/百合种苗案例参考 - 新闻快传
  • 告别龟速与超时:全方位解决 git clone 网络难题的实战指南
  • 嵌入式MCU电气特性与FLASH操作深度解析:从数据手册到稳定设计
  • 2026 郑州八大装修公司综合实力排行榜 - GrowthUME
  • 爱回收到店估价和到手价差多少?iPhone 15 Pro实测报告 - 新闻快传
  • 2026沈阳非急救转运救护车TOP5盘点|辽中同城、浑河跨桥、棋盘山山地、院区转诊首选康跃转运 - 吉修匠

日新闻

  • 5分钟掌握Python进化算法:Geatpy高性能优化工具完全指南
  • Microchip 24AA044 EEPROM选型与应用全指南:从参数解析到实战编程
  • 华为的鸿蒙到底有多牛?为什么称作遥遥领先?

周新闻

  • 3步解锁iOS设备:applera1n激活锁绕过完全指南
  • 39 2026 人工智能证书终极盘点,普通人选 AI 证书可以从这些方向入手
  • Redis 暴露公网有多危险?从端口检查到补救步骤

月新闻

  • 【总结】入门篇:50句话让你记住架构核心概念
  • WeChatMsg技术方案解析:实现Mac微信数据自主管理的完整解决方案
  • WeChatMsg:革新性微信数据备份方案,打造你的专属数字记忆库

关于尧图

  • 公司简介
  • 团队介绍
  • 企业文化
  • 荣誉资质

服务项目

  • 定制开发
  • 电商建站
  • UI 设计
  • 运维服务

快速链接

  • 案例展示
  • 建站流程
  • 常见问题
  • 资讯中心

联系方式

  • 📍北京市朝阳区互联网产业园 A 座 10 层
  • 📞400-888-8888
  • ✉️contact@rkmt.cn
  • 🕐周一至周日 9:00-21:00

© 2024 北京尧图网络科技有限公司 版权所有 | 京 ICP 备 XXXXXXXX 号