Cod sursa(job #7480)

Utilizator a7893Nae Mihai a7893 Data 21 ianuarie 2007 16:09:48
Problema Elimin Scor 0
Compilator cpp Status done
Runda Arhiva de probleme Marime 1.14 kb
#include<stdio.h>
void trs(int v[100],int k,int p)
{
	int i;
	for(i=p;i<k-1;i++)
		v[i]=v[i+1];
}
int main()
{
	int n,m,r,c,a[100][100],min,s=0,poz=0,i,j,b[100][100],u,k,h;
	freopen("elimin.in","r",stdin);
	freopen("elimin.out","w",stdout);
	scanf("%d%d%d%d",&n,&m,&r,&c);
	for(i=0;i<m;i++)
		for(j=0;j<n;j++)
			scanf("%d",&a[i][j]);
	for(h=0;h<r;h++)
	{
		for(j=0;j<n;j++)
			s+=a[0][j];
		min=s;
		s=0;
		for(i=0;i<m;i++)
		{
			s=0;
			for(j=0;j<n;j++)
				s+=a[i][j];
			if(s<min)
			{
				min=s;
				poz=i;
			}
		}	
		u=k=0;
		for(i=0;i<m;i++)
			if(i!=poz)
			{
				k=0;
				for(j=0;j<n;j++)
					b[u][k++]=a[i][j];
				u++;
			}
		for(i=0;i<u;i++)
			for(j=0;j<k;j++)
				a[i][j]=b[i][j];
		m=u;
		n=k;
	}
	for(h=0;h<c;h++)
	{		
		s=0;
		for(i=0;i<m;i++)
			s+=b[i][0];
		min=s;
		poz=0;
		for(j=0;j<n;j++)
		{
			s=0;
			for(i=0;i<m;i++)
				s+=a[i][j];
			if(s<min)
			{
				min=s;
				poz=j;
			}
		}
		for(i=0;i<m;i++)
			for(j=0;j<n;j++)
				if(j==poz)
					trs(a[i],n,j);
		n--;
	}
	s=0;
	for(i=0;i<m;i++)
		for(j=0;j<n;j++)
			s+=a[i][j];
	printf("%d",s);	
	return 0;
}