Pagini recente » Cod sursa (job #3232876) | Cod sursa (job #2930024) | Cod sursa (job #1407413) | Cod sursa (job #2553405) | Cod sursa (job #280000)
Cod sursa(job #280000)
#include <stdio.h>
#include <string.h>
int n,m,i,j,k,nod,a[101],b[101],q[101],l[101][101];
int main(){
freopen("harta.in","r",stdin); freopen("harta.out","w",stdout);
scanf("%d",&n);
for (i=1;i<=n;++i){scanf("%d %d",&a[i],&b[i]);m+=a[i];}
printf("%d\n",m);
for (i=1;i<=n;++i){
memset(q,0,sizeof(q));
for (j=1;j<=n;++j)if (b[j]&&i!=j){l[b[j]][++q[b[j]]]=j;}
for (j=n;j&&a[i];--j)
for (k=q[j];k&&a[i];--k){
nod=l[j][k]; a[i]--; b[nod]--;
printf("%d %d\n",i,nod);
}
}
return 0;
}