Pagini recente » Cod sursa (job #1116709) | Cod sursa (job #2605885) | Cod sursa (job #2760823) | Cod sursa (job #2347086) | Cod sursa (job #65243)
Cod sursa(job #65243)
var f1,f2:text;
n,t,i,j,k,max,aux,w,e,q,q1,w1,e1:longint;
x,y,z,v,ax:array[1..4000] of longint;
a:array[1..4000] of qword;
procedure pozitie(var m:longint; p,u:longint);
var i,j,di,dj:longint;
aux:qword;
begin
di:=0;
dj:=-1;
i:=p;
j:=u;
while i<j do
begin
if a[i]>a[j] then
begin
aux:=di;
di:=-dj;
dj:=-aux;
aux:=a[i];
a[i]:=a[j];
a[j]:=aux;
end;
i:=i+di;
j:=j+dj;
end;
m:=i;
end;
procedure quick(p,u:longint);
var m:longint;
begin
if p<u then
begin
pozitie(m,p,u);
quick(p,m-1);
quick(m+1,u);
end;
end;
begin
assign(f1,'cutii.in');
reset(f1);
assign(f2,'cutii.out');
rewrite(f2);
read(f1,n,t);
for k:=1 to t do
begin
for i:=1 to n do
begin
read(f1,x[i],y[i],z[i]);
a[i]:=x[i];a[i]:=a[i]*100000000;
a[i]:=a[i]+y[i]*10000;
a[i]:=a[i]+z[i];
end;
quick(1,n);
for i:=1 to n do
begin
x[i]:=a[i] div 100000000;
y[i]:=a[i] mod 100000000 div 10000;
z[i]:=a[i] mod 10000;
end;
for i:=n downto 1 do
begin
max:=0;
for j:=i+1 to n do
begin
if (x[i]<x[j])and(y[i]<y[j])and(z[i]<z[j])and(v[j]>max) then max:=v[j];
if n-j=max then break;
end;
v[i]:=max+1;
end;
max:=0;
for i:=1 to n do
begin
if max<v[i] then max:=v[i];
v[i]:=0;
end;
writeln(f2,max);
end;
close(f1);
close(f2);
end.