Pagini recente » Cod sursa (job #1436145) | Cod sursa (job #712019) | Cod sursa (job #2796572) | Cod sursa (job #2053987) | Cod sursa (job #2578137)
//#include <iostream>
#include <fstream>
#include <algorithm>
using namespace std;
ifstream cin("cutii.in");
ofstream cout("cutii.out");
int aib[3550][3550],n;
void u(int a,int b,int val){
for(int i=a;i<=n;i+=(i&(-i))){
for(int j=b;j<=n;j+=(j&(-j))){
aib[i][j]=max(val,aib[i][j]);
}
}
}
void r(int a,int b){
for(int i=a;i<=n;i+=(i&(-i))){
for(int j=b;j<=n;j+=(j&(-j))){
aib[i][j]=0;
}
}
}
int q(int a,int b){
int sum=0;
for(int i=a;i>=1;i-=(i&(-i))){
for(int j=b;j>=1;j-=(j&(-j))){
sum=max(aib[i][j],sum);
}
}
return sum;
}
pair<int,pair<int,int> > v[3550];
int vect[3500];
int main()
{
int t;
cin>>n>>t;
while(t--){
for(int i=1;i<=n;i++){
cin>>v[i].first>>v[i].second.first>>v[i].second.second;
}
sort(v+1,v+n+1);
int sum=0,pr=1;
for(int i=1;i<=n;i++){
if(v[i].first!=v[i-1].first){
for(int j=pr;j<i;j++){
//cout<<"="<<i<<" "<<j<<"=";
//u(v[j].second.first,v[j].second.second,1);
vect[j]=q(v[j].second.first-1,v[j].second.second-1)+1;
sum=max(sum,vect[j]);
}
for(int j=pr;j<i;j++){
u(v[j].second.first,v[j].second.second,vect[j]);
}
pr=i;
sum=max(sum,q(v[i].second.first-1,v[i].second.second-1)+1);
}
}
for(int j=pr;j<=n;j++){
sum=max(sum,q(v[j].second.first-1,v[j].second.second-1)+1);
}
for(int i=1;i<=n;i++){
r(v[i].second.first,v[i].second.second);
}
cout<<sum<<"\n";
}
return 0;
}
/*
3 1
3 3 3
2 2 2
3 1 1
3 1
2 2 2
3 1 1
3 3 3
*/