当前位置: 首页 > news >正文

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

最长严格/非严格递增子序列 (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 << " ";
}
http://www.jsqmd.com/news/21237/

相关文章:

  • 【Python爬虫】反爬虫入门与基础(一) - 教程
  • sg
  • 解决复制 Ubuntu Server 虚拟机后网络不通的问题(IP冲突问题)
  • postgresql查询数据sql无法使用到索引
  • 博弈1
  • Day3综合案例一:个人简介
  • 后缀数组 SA
  • 自动机
  • 1024程序员节福利!参与互动,5分钟赢好礼!
  • 马拉车
  • 具身智能/智能体 定义
  • 【数据挖掘】基于随机森林回归模型的二手车价格预测分析(信息集+源码)
  • 实用指南:flink批处理-水位线
  • 字符串模式匹配算法 KMP
  • Z函数(扩展 KMP)
  • 常用例题
  • 实验报告3
  • 2025年环评公司权威推荐排行榜,环评手续,环评报告,环评验收,专业高效服务助力企业合规发展
  • 2025年棒球帽厂家推荐排行榜,运动棒球帽,时尚棒球帽,定制棒球帽,防晒棒球帽公司精选榜单
  • 常见结论与例题
  • 单芯片方案分享-CH336F-USB拓展坞+百兆网卡+读卡器+100W快充芯片
  • 于状压的线性 RMQ 算法
  • Flink编程模型 - 详解
  • 工业4.0下的边缘存储设计:材料就地处理,响应更快更安全
  • 服务器关机用halt、poweroff还是shutdown -h now?一文帮你说明
  • KD Tree
  • 小波矩阵树:高效静态区间第 K 大查询
  • Seata用法
  • Day3多媒体标签——视频与音频
  • 分数运算类