Cod sursa(job #796353)

Utilizator kiralalaChitoraga Dumitru kiralala Data 11 octombrie 2012 10:03:17
Problema Jocul Flip Scor 20
Compilator cpp Status done
Runda Arhiva de probleme Marime 1.55 kb
#include<fstream>

using namespace std;

ifstream f("flip.in");
ofstream o("flip.out");

int tabla[16][16],sumneg,sumpos,n,m;
long sum;
int checkRow(int i)
{
    sumneg=sumpos=0;
    for(int j=0;j<m;j++)
    {
        if(tabla[i][j]>=0)
        {
            sumpos+=tabla[i][j];
        }
        else
        {
            sumneg+=tabla[i][j];
        }
    }
    if(sumpos>=-sumneg)
        return 1;
    else
        return 0;
}

int checkCol(int i)
{
    sumneg=sumpos=0;
    for(int j=0;j<n;j++)
    {
        if(tabla[j][i]>=0)
        {
            sumpos+=tabla[j][i];
        }
        else
        {
            sumneg+=tabla[j][i];
        }
    }
    if(sumpos>=-sumneg)
        return 1;
    else
        return 0;
}

void performFlipRow(int i)
{
    for(int j=0;j<m;j++)
    {
        tabla[i][j]*=-1;
    }
}

void performFlipCol(int i)
{
    for(int j=0;j<n;j++)
    {
        tabla[j][i]*=-1;
    }
}

int main()
{
	int i,j;
	f>>n>>m;
	for(i=0;i<n;i++)
	{
        for(j=0;j<m;j++)
            {
                f>>tabla[i][j];
                if(j==m-1)
                {
                    if(!checkRow(i))
                    {
                        performFlipRow(i);
                    }

                }
            }
	}
	for(j=0;j<m;j++)
       {
           if(!checkCol(j))
           {
               performFlipCol(j);
           }
       }
    for(i=0;i<n;i++)
	{
        for(j=0;j<m;j++)
            sum+=tabla[i][j];
	}
	o<<sum;


	return 0;

}