data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt="" /**//*
给出如图的电路布线,求最大的一块,其中里面的线两两相交
n<=10^6
看解题报告的:
http://itbhu.ac.in/codefest/problem.php?pid=102
它说这是一个Permutation Graph
先将上面那排的数字映射为1,2, ,n,然后下面那排再映射一下
其中的最大图就是最长下降子序列了 -------------------------------OMG
O(nlogn)
*/
#include<iostream>
#include<cstring>
#include<map>
#include<algorithm>
#include<stack>
#include<queue>
#include<cmath>
#include<string>
#include<cstdlib>
#include<vector>
#include<cstdio>
#include<set>
#include<list>
#include<numeric>
#include<cassert>
#include<ctime>
#include<bitset>
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
using namespace std;
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
const int MAXN = 1000010;
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
int a[MAXN];
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt="" bool cmp(const int &a , const int &b) {
return a > b;
}
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
int main()
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt="" data:image/s3,"s3://crabby-images/c9e2b/c9e2bc817d66f0a3894ba04ea7703b8e0b7b6162" alt="" {
#ifndef ONLINE_JUDGE
freopen("in","r",stdin);
#endif
ios::sync_with_stdio(false);//取消跟stdin的同步 然后cin,cout就不要跟scanf,printf混用了
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" for (int n ; cin>>n ; ) {
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" for (int i = 1, x ; i <= n ; i++) {
cin>>x;
a[x] = i;//
}
vector<int> rec;
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" for (int i = 1, x; i <= n ; i ++) {
cin>>x;
x = a[x];//
int pos = upper_bound(rec.begin(), rec.end(), x, cmp) - rec.begin();
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" if(pos == rec.size()) {
rec.push_back(0);
}
rec[pos] = x;
}
cout<<rec.size()<<endl;
}
return 0;
}
|
|
常用链接
随笔分类
Links
搜索
最新评论
data:image/s3,"s3://crabby-images/93320/93320ba8164624c7c09e7cba1edb2fec259b84ff" alt=""
|
|