Cod sursa(job #2910524)

Utilizator XelaethAlexandru Obreja Xelaeth Data 21 iunie 2022 21:00:15
Problema Jocul Flip Scor 40
Compilator cpp-64 Status done
Runda Teme Pregatire ACM Unibuc 2014, Anul II Marime 0.88 kb
#include <bits/stdc++.h>

using namespace std;
bool flipc[20], flipl[20];
long long a[20][20], c, l, maxi = INT_MIN;
void backt(int m, int n)
{
    if(m==l+1&&n==c+1)
    {
        int s = 0;
        for(int i = 1; i<=l;i++)
            for(int j = 1; j<=c; j++)
                s+=a[i][j]*(flipc[j]*2-1)*(flipl[i]*2-1);
        if(s>maxi)
            maxi = s;
    }
    else if(m!=l+1)
        for(int i = 0; i<=1; i++)
        {
            flipl[m] = i;
            backt(m+1,n);
        }
    else
        for(int i = 0; i<=1; i++)
        {
            flipc[n] = i;
            backt(m,n+1);
        }
}
int main()
{
    ifstream f("flip.in");
    ofstream g("flip.out");
    f>>l>>c;
    for(int i = 1; i<=l; i++)
        for(int j = 1; j<=c; j++)
            f>>a[i][j];

    backt(1,1);
    g<<maxi;
    f.close();
    g.close();
    return 0;
}