Cod sursa(job #1748970)

Utilizator LucianTLucian Trepteanu LucianT Data 27 august 2016 16:10:41
Problema Elimin Scor 40
Compilator cpp Status done
Runda Arhiva de probleme Marime 1.05 kb
#include <bits/stdc++.h>
#define maxN 7300
using namespace std;
int a[maxN][20],sum[maxN],x[maxN];
int n,m,r,c,i,j,sol;
void solve()
{
    int i;
    for(i=1;i<=n;i++)
        sum[i]=0;
    for(i=1;i<=n;i++)
    {
        for(j=1;j<=m;j++)
            sum[i]+=a[i][j];
        for(j=1;j<=c;j++)
            sum[i]-=a[i][x[j]];
    }
    sort(sum+1,sum+n+1);
    int S=0;
    for(i=r+1;i<=n;i++)
        S+=sum[i];
    sol=max(sol,S);
}
void bkt(int k)
{
    if(k==c+1)
    {
        solve();
        return;
    }
    for(int i=x[k-1]+1;i<=m;i++)
        x[k]=i,bkt(k+1);
}
int main()
{
    freopen("elimin.in","r",stdin);
    freopen("elimin.out","w",stdout);
    scanf("%d %d %d %d",&n,&m,&r,&c);
    if(n>=m)
    {
        for(i=1;i<=n;i++)
            for(j=1;j<=m;j++)
                scanf("%d",&a[i][j]);
    }
    else
    {
        swap(n,m);
        swap(r,c);
        for(j=1;j<=n;j++)
            for(i=1;i<=m;i++)
                scanf("%d",&a[i][j]);
    }
    bkt(1);
    printf("%d",sol);
    return 0;
}