标签:输出 getchar sam char getch 数据约束 std 组成 它的
[数据约束和评分方法]
60%的测试数据中:1<=N <= 1 000
100%的测试数据中:1<=N <= 20 000
题解:回忆求最长公共子序列的过程,转移矩阵差分后实际上就是一个01矩阵,我们将1看成二位平面上的一堆点,然后就变成了一条路径最多能经过多少个点。由于本题的特殊性质,点数=25N,所以用树状数组即可。
#include <cstdio> #include <cstring> #include <iostream> using namespace std; const int maxn=100010; int n; int a[maxn],b[maxn],p[maxn][7],s[maxn]; inline void updata(int x,int val) { for(int i=x;i<=5*n;i+=i&-i) s[i]=max(s[i],val); } inline int query(int x) { int i,ret=0; for(i=x;i;i-=i&-i) ret=max(ret,s[i]); return ret; } inline int rd() { int ret=0,f=1; char gc=getchar(); while(gc<‘0‘||gc>‘9‘) {if(gc==‘-‘) f=-f; gc=getchar();} while(gc>=‘0‘&&gc<=‘9‘) ret=ret*10+gc-‘0‘,gc=getchar(); return ret*f; } int main() { int i,j,v; n=rd(); for(i=1;i<=5*n;i++) v=rd(),p[v][++p[v][0]]=i; for(i=1;i<=5*n;i++) { v=rd(); for(j=5;j>=1;j--) updata(p[v][j],query(p[v][j]-1)+1); } printf("%d",query(5*n)); return 0; }
【BZOJ1264】[AHOI2006]基因匹配Match DP+树状数组
标签:输出 getchar sam char getch 数据约束 std 组成 它的
原文地址:http://www.cnblogs.com/CQzhangyu/p/7707887.html