Cerința
Se consideră o clădire de formă dreptunghiulară, împărțită în n*m
camere, dispuse sub forma unei matrice cu n
linii și m
coloane. Dintr-o cameră se poate trece în oricare dintre cele 4
camere vecine pe linie sau pe coloană. Unele camere sunt închise, și în ele nu se poate intra deloc. Trecerea dintr-o cameră în altă cameră durează un minut.
În anumite camere se află echipe de pompieri. Pentru o intervenție cât mai rapidă în cazul unui eventual incendiu apărut în una dintre camerele clădirii, este necesar să se știe, pentru fiecare cameră care este timpul minim în care o echipă de pompieri ajunge în acea cameră.
Date de intrare
Fișierul de intrare acces1.in
conține pe prima linie numerele n m
; următoarele n
linii conțin câte m
caractere, care pot fi:
-
– reprezintă o cameră liberă#
– reprezintă o cameră închisăP
– reprezintă o cameră în care se găsește o echipă de pompieri
Date de ieșire
Fișierul de ieșire acces1.out
va conține o matrice cu n
linii și m
coloane, fiecare element al matricei reprezentând timpul minim necesar ca o echipă de pompieri să ajungă în camera corespunzătoare. Pentru camerele ocupate se va fișa simbolul #
, iar pentru cele libere în care nu va ajunge nici o echipă se va afișa -
.
Matricea va fi afișată linie cu linie, câte o linie a matricei pe o linie a fișierului, elementele de pe fiecare linie fiind separate prin câte un spațiu.
Restricții și precizări
1 ≤ n,m ≤ 1000
Exemplu
acces1.in
4 6 P-#-#P --##-- --P--- -----#
acces1.out
0 1 # - # 0 1 2 # # 2 1 2 1 0 1 2 2 3 2 1 2 3 #
Cum e corect?
cout < "As la info";
cout << "As la info";
cout >> "As la info";
Felicitări! Poți mai mult?
Avem sute de probleme pentru tine, fiecare cu explicații ușor de înțeles.
Greșit, dar nu-i bai!
Antrenează-te cu sutele de probleme pe care ți le-am pregătit. Îți explicăm fiecare problemă în parte.
Rezolvare
Iată rezolvarea de 100 de puncte pentru problema Acces1:
#include <iostream>
#include <fstream>
#include <cassert>
using namespace std;
ifstream fin("acces1.in");
ofstream fout("acces1.out");
int n , m;
short a[1001][1001];
int x[1000001], y[1000001];
char P[1001][1001];
const int dx[] = {0 , 0 , 1 , -1},
dy[] = {1 , -1 , 0 , 0};
int main(){
fin >> n >> m;
int st = 1 , dr = 0;
for(int i = 1 ; i <= n ; i ++)
for(int j = 1 ; j <= m ; j ++)
{
fin >> P[i][j];
if(P[i][j] == 'P')
{
dr ++;
x[dr] = i, y[dr] = j;
a[i][j] = 1;
}
}
fin.close();
while(st <= dr)
{
int i = x[st], j = y[st];
for(int k = 0 ; k < 4 ; k ++)
{
int ii = i + dx[k], jj = j + dy[k];
if( ii > 0 && ii <= n && jj > 0 && jj <= m && P[ii][jj] !='#' && a[ii][jj] == 0)
{
a[ii][jj] = a[i][j] + 1;
dr ++;
x[dr] = ii, y[dr] = jj;
}
}
st ++;
}
for(int i = 1 ; i <= n ; i ++)
{
for(int j = 1 ; j <= m ; j ++)
if(a[i][j] > 0)
fout << a[i][j] - 1 << " ";
else
fout << P[i][j] << " ";
fout << "\n";
}
fout.close();
return 0;
}
Atenție
Enunțurile afișate pe această pagină aparțin exclusiv site-ului PbInfo. Astfel, pentru ștergerea conținutului, puteți să ne contactați la adresa .
Rezolvarea problemei #868 Acces1
Pe această pagină găsești rezolvarea de 100 de puncte pentru problema #868 Acces1 de pe PbInfo.ro. Atenție: nu încurajăm copiatul codului! Totuși, credem cu tărie că analizarea unei soluții corecte este o metodă foarte ușoară de a învăța informatică, astfel că oferim sursele pentru peste 1500 de probleme de pe platforma PbInfo.ro.
Pentru rezolvări PbInfo de la peste 1500 de probleme, vă invităm să intrați pe site-ul nostru!