Cod sursa(job #2578137)

Utilizator NashikAndrei Feodorov Nashik Data 10 martie 2020 16:54:23
Problema Cutii Scor 100
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 1.85 kb
//#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
*/