Cod sursa(job #697907)

Utilizator harababurelPuscas Sergiu harababurel Data 29 februarie 2012 11:34:31
Problema Jocul Flip Scor 30
Compilator cpp Status done
Runda Arhiva de probleme Marime 1.07 kb
#include <iostream>
#include <fstream>
using namespace std;
short n, m;
int a[20][20];
ifstream f("flip.in");
ofstream g("flip.out");

void citire() {
	f>>n>>m;
	int i, j;
	for(i=1; i<=n; i++)
		for(j=1; j<=m; j++) f>>a[i][j];
}
void verifica_linii() {
	int i, j;
	long long s;
	for(i=1; i<=n; i++) {
		s=0;
		for(j=1; j<=m; j++) s+=a[i][j];
		
		if(s<0) {
			for(j=1; j<=m; j++) a[i][j]*=-1;
		}
	}
}

void verifica_coloane() {
	int i, j;
	long long s;
	for(i=1; i<=m; i++) {
		s=0;
		for(j=1; j<=n; j++) s+=a[j][i];
		
		if(s<0) {
			for(j=1; j<=n; j++) a[j][i]*=-1;
		}
	}
}

int tipardeproba() {
	int i, j;
	long long s=0;
	for(i=1; i<=n; i++) {
		for(j=1; j<=m; j++) {
			//g<<a[i][j]<<" "; 
			s+=a[i][j];
		}
		//g<<"\n";
	}
	return s;
}
	

int main() {
	citire();
	long long k;
	verifica_linii();
	verifica_coloane();
	k=tipardeproba();
	
	while(1) {
		verifica_linii();
		verifica_coloane();
		if(tipardeproba()==k) { break; }
		else { k=tipardeproba(); }
	}
	g<<k;
		
	f.close();
	g.close();
	return 0;
}