Pagini recente » Cod sursa (job #1390160) | Cod sursa (job #988299) | Cod sursa (job #1693842) | Cod sursa (job #2972108) | Cod sursa (job #2046484)
#include <fstream>
#include <algorithm>
#define DIM 3502
using namespace std;
ifstream f("cutii.in");
ofstream g("cutii.out");
int n, T, res, aib[DIM][DIM];
struct cutie{
int x, y, z;
}c[DIM];
bool cmp(cutie a, cutie b){
return a.z < b.z;
}
int query(int i, int j){
int s = 0;
for( ; i; i -= (i & -i))
for( ; j; j -= (j & -j))
s = max(s, aib[i][j]);
return s;
}
void update(int i, int j, int val){
for(; i <= n; i += (i & -i))
for(; j <= n; j += (j & -j))
aib[i][j] += val;
}
void curata(int i, int j){
for(; i <= n; i += (i & -i))
for(; j <= n; j += (j & -j))
aib[i][j] = 0;
}
int main()
{
f>>n>>T;
for(int t = 1; t <= T; ++ t){
for(int i = 1; i <= n; ++ i)
f>>c[i].x>>c[i].y>>c[i].z;
sort(c + 1, c + n + 1, cmp);
for(int i = 1; i <= n; ++ i){
int rez = query(c[i].x - 1, c[i].y - 1);
update(c[i].x, c[i].y, rez + 1);
}
g<<query(n, n)<<'\n';
for(int i = 1; i <= n; ++ i){
curata(c[i].x, c[i].y);
}
}
return 0;
}