Pagini recente » Cod sursa (job #473505) | Cod sursa (job #246622) | Cod sursa (job #138604) | Cod sursa (job #2421249) | Cod sursa (job #1042138)
Program jocul_flip;
type vector=array[1..20] of boolean;
var i,j,sum,n,m,k,max:integer;
f,g:text;
a:array[1..20,1..20] of longint;
b:vector;
FUnction suma(var b:vector):integer;
var s,sf,x,y:integer;
begin
sf:=0;
for x:=1 to m do
begin
s:=0;
for y:=1 to n do
if b[y] then s:=s+(a[y,x]*(-1)) else s:=s+a[y,x];
sf:=sf+abs(s);
end;
suma:=sf;
end;
BEGIN
assign(f,'flip.in');
reset(f);
read(f,n,m);
sum:=0;
for i:=1 to n do
for j:=1 to m do
begin
read(f,a[i,j]);
sum:=sum+a[i,j];
end;
for i:=1 to (1 shl n)-1 do
begin
for k:=1 to n do
b[k]:=false;
for j:=0 to n-1 do
if ((1 shl j) and i) > 0 then b[j+1]:=true;
max:=suma(b);
if max>sum then sum:=max;
end;
assign(g,'flip.out');
rewrite(g);
writeln(g,sum);
close(f);
close(g);
END.