当前位置: 首页 > 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.rkmt.cn/news/29266.html

相关文章:

  • 博弈1
  • 1024程序员节福利!参与互动,5分钟赢好礼!
  • 马拉车
  • 具身智能/智能体 定义
  • 实用指南:flink批处理-水位线
  • 2025年棒球帽厂家推荐排行榜,运动棒球帽,时尚棒球帽,定制棒球帽,防晒棒球帽公司精选榜单
  • 常见结论与例题
  • 单芯片方案分享-CH336F-USB拓展坞+百兆网卡+读卡器+100W快充芯片
  • 于状压的线性 RMQ 算法
  • KD Tree
  • 小波矩阵树:高效静态区间第 K 大查询
  • 分数运算类
  • 坐标压缩与离散化
  • 撸一个功能强大的基于语义的图像检索系统
  • 数论常见结论及例题
  • N8N Workflow Collection - 专业级自动化工作流库 - 详解
  • 莫比乌斯函数/反演
  • 同余方程组、拓展中国剩余定理 excrt
  • Apache POI 在 Linux 无图形界面环境下因字体配置问题导致Excel导出失败的解决方案 - 详解
  • 扩展欧几里得 exgcd
  • 防爆模乘
  • 20232314 2025-2026-1 《网络与系统攻防技术》实验三实验报告
  • 最小割树 Gomory-Hu Tree
  • 图论常见结论及例题
  • 最短路径树(SPT问题)
  • 多源汇最短路(APSP问题)
  • 单源最短路径(SSSP问题)
  • 最近公共祖先 LCA
  • 题解:P3343 [ZJOI2015] 地震后的幻想乡
  • 暂存:P14214 [COI 2010] 圆圈 / KOLO