fbpx

Problema #566 – Mese – Rezolvari PBInfo

de Mihai-Alexandru

Cerința

Gigel este patronul unui fast-food destul de cunoscut. Restaurantul are formă dreptunghiulară, și conține mai multe mese de formă de asemenea dreptunghiulară dar de dimensiuni neregulate. Gigel vă pune la dispoziție planul restaurantului, sub forma unei matrice cu n linii și m coloane, în care elementele care corespund unor spații libere sunt egale cu 0, iar elementele care fac parte din mese sunt egale cu 1. Mai precis, mesele sunt zone dreptunghiulare maximale din matrice care au toate elementele 1.

Rugămintea lui Gigel este să aflați câte mese sunt în local și care este suprafața maximă unei mese.

Date de intrare

Programul citește de la tastatură numerele n m, iar apoi n*m numere naturale (0 sau 1), dispuse pe n ,linii, reprezentând planul restaurantului.

Date de ieșire

Programul va afișa pe ecran numerele C M, separate prin exact un spațiu reprezentând numărul total de mese și suprafața maximă a unei mese.

Restricții și precizări

  • 1 ≤ n, m ≤ 250
  • mesele nu au laturi comune
  • nici o masă nu va conține spații libere
  • suprafața unei mese este egală cu numărul de elemente din matrice din care este alcătuită

Exemplu

Intrare

5 6
0 0 1 1 1 0
0 0 1 1 1 0
1 0 0 0 0 1
1 0 1 1 0 1
1 0 1 1 0 0

Ieșire

4 6
#include <bits/stdc++.h>
using namespace std;
const int di[]={-1 , 0 , 1 , 0};
const int dj[]={0 , 1 , 0 , -1};
int n , m , a[1002][1002] , x[1000001] , y[1000001];
int ip , jp , is , js;
bool inside(int i , int j)
{
    return i>=1 && i<=n && j>=1 && j<=m;
}
void lee(int ip , int jp)
{
    int st = 1 , dr = 1;
    a[ip][jp] = 2;
    x[1]=ip;
    y[1]=jp;
    while(st <= dr)
    {
        int i= x[st] , j = y[st];
        for(int k = 0 ; k < 4 ; k++)
        {
            int ii = i+di[k];
            int jj = j+dj[k];
            if(inside(ii , jj) && a[ii][jj]==1)
            {
                dr++;
                x[dr]=ii;
                y[dr]=jj;
                a[ii][jj]=2;
            }}st++;}
}
int main()
{
    int p = 0 , k = 0 , max = 0;
    cin >> n >> m;
    for(int i = 1 ; i <=n ; ++i)
        for(int j = 1 ; j <=m ; ++j)
            cin >> a[i][j];
    for(int i = 1 ; i <= n ; ++i)
        for(int j = 1 ; j <= m ; ++j)
            if(a[i][j]==1)
            {
                int lat = 0 , col = 0;
                while(a[i][j]==1){lat++;j++;}
                j-=lat;
                while(a[i][j]==1){col++;i++;}
                if(lat * col>max) max=lat*col;
                i-=col;
            }
    for(int i = 1 ; i <=n ; ++i)
    {
        if(a[i][1]==1){p++;lee(i,1);}
        if(a[i][m]==1){p++;lee(i,m);}
    }
    for(int i = 1 ; i <=m ; ++i)
    {
        if(a[1][i]==1){p++;lee(1,i);}
        if(a[n][i]==1){p++;lee(n,i);}
    }
    for(int i = 2 ; i <n ; ++i)
        for(int j = 2 ; j <m ; ++j)
            if(a[i][j]==1)
            {
                k++;
                lee(i,j);
            }
    cout << k+p << " " << max;
    return 0;
}
Comentarii

S-ar putea sa iti placa