Cod sursa(job #234085)

Utilizator AndreiDDiaconeasa Andrei AndreiD Data 19 decembrie 2008 22:17:10
Problema Tablete Scor 80
Compilator c Status done
Runda Arhiva de probleme Marime 1.78 kb
#include <stdio.h>   
  
int A[1000][1000];     
  
int main()   
{   
    int N,K;
    freopen("tablete.in","r",stdin);   
    scanf("%d %d", &N,&K);   
    int p;
    if (K%2==0)p=K;
      else
    if (N%2==0 && K%2==1 && (K/2)%2==0)
            p=(N*K)-(N+(K/2)+2);
      else
      if (N%2==1 && K%2==1 && (K/2)%2==0)
            p=(N*K)-(N+(K/2));
      else p=(N*K)-(N+(K/2)+1);
    int i;
    int frecv[1000000];
    for (i=1;i<=N;++i)   
         {   
           A[i][K]=p;   
           frecv[p]=1;
           p+=2;   
         }   
    int nr=1,j;
    for (i=1;i<=N;++i)
          for (j=1;j<K;++j)
            {
                   if (frecv[nr]==0)
                        {
                         A[i][j]=nr;
                         frecv[nr]=1;
                        }
                   else
                   {
                    while (frecv[nr]==1)
                   nr++;
                   A[i][j]=nr;
                   frecv[nr]=1;
                   }
                 nr++;  
                 }
              nr++;   
              for (i=1;i<=N;++i)   
              for (j=K+1;j<=N;++j)
              {   
               if (frecv[nr]==0)
                        {
                         A[i][j]=nr;
                         frecv[nr]=1;
                        }
                   else
                   {
                   while (frecv[nr]==1)
                   nr++;
                   A[i][j]=nr;
                   frecv[nr]=1;
                   }
                nr++;   
              }   
     freopen("tablete.out","w",stdout);
     for (i=1;i<=N;++i)   
     {   
      for (j=1;j<=N;++j)   
      printf("%d ", A[i][j]);   
      printf("\n");   
     }   
return 0;   
}