您的位置:首页 > 教育 > 锐评 > 室内设计装修大全_免费网站怎么赚钱_百度手机助手下载安卓_邯郸seo优化

室内设计装修大全_免费网站怎么赚钱_百度手机助手下载安卓_邯郸seo优化

2025/11/8 23:40:11 来源:https://blog.csdn.net/2202_75344116/article/details/146964792  浏览:    关键词:室内设计装修大全_免费网站怎么赚钱_百度手机助手下载安卓_邯郸seo优化
室内设计装修大全_免费网站怎么赚钱_百度手机助手下载安卓_邯郸seo优化

题目链接:

思路:

我们可以先对河岸一边从小到大排序,对于另外一边,就转换为求最长上升子序列的问题了。

二分+贪心代码:

#include<bits/stdc++.h>
using namespace std;
const int N = 2e5+10;int n;
struct edge{int x, y;
}p[N];
//g[i] 表示长度为i的子序列最后数字
int len = 1, g[N];//sort判断函数
bool cmp(edge a, edge b){return a.x < b.x;
}int main(){cin >> n;//读入for(int i = 1; i <= n; i++){cin >> p[i].x >> p[i].y;}//对p根据x从小到大排序sort(p+1, p+1+n, cmp);//对p[i]选出最长上升子序列g[1] = p[1].y;for(int i = 2; i <= n; i++){//当满足上升 添加到g[]中if(g[len] <=  p[i].y){g[++len] = p[i].y;}else{//不满足int l = 0, r = len+1;while(l+1 < r){int mid = (l+r) / 2;if(g[mid] < p[i].y){l = mid;}else r = mid;}g[r] = p[i].y;}}cout << len << endl;return 0;
}

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com