<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
	<id>https://wiki.universitas.ro/index.php?action=history&amp;feed=atom&amp;title=0868_-_Acces1</id>
	<title>0868 - Acces1 - Revision history</title>
	<link rel="self" type="application/atom+xml" href="https://wiki.universitas.ro/index.php?action=history&amp;feed=atom&amp;title=0868_-_Acces1"/>
	<link rel="alternate" type="text/html" href="https://wiki.universitas.ro/index.php?title=0868_-_Acces1&amp;action=history"/>
	<updated>2026-05-01T06:38:38Z</updated>
	<subtitle>Revision history for this page on the wiki</subtitle>
	<generator>MediaWiki 1.42.1</generator>
	<entry>
		<id>https://wiki.universitas.ro/index.php?title=0868_-_Acces1&amp;diff=7673&amp;oldid=prev</id>
		<title>Bonte Lucas Gabriel: Pagină nouă: ==Cerința==  Se consideră o clădire de formă dreptunghiulară, împărțită în &#039;&#039;&#039;n*m&#039;&#039;&#039; camere, dispuse sub forma unei matrice cu &#039;&#039;&#039;n&#039;&#039;&#039; linii și &#039;&#039;&#039;m&#039;&#039;&#039; coloane. Dintr-o cameră se poate trece în oricare dintre cele &#039;&#039;&#039;4&#039;&#039;&#039; 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 ma...</title>
		<link rel="alternate" type="text/html" href="https://wiki.universitas.ro/index.php?title=0868_-_Acces1&amp;diff=7673&amp;oldid=prev"/>
		<updated>2023-12-07T18:11:19Z</updated>

		<summary type="html">&lt;p&gt;Pagină nouă: ==Cerința==  Se consideră o clădire de formă dreptunghiulară, împărțită în &amp;#039;&amp;#039;&amp;#039;n*m&amp;#039;&amp;#039;&amp;#039; camere, dispuse sub forma unei matrice cu &amp;#039;&amp;#039;&amp;#039;n&amp;#039;&amp;#039;&amp;#039; linii și &amp;#039;&amp;#039;&amp;#039;m&amp;#039;&amp;#039;&amp;#039; coloane. Dintr-o cameră se poate trece în oricare dintre cele &amp;#039;&amp;#039;&amp;#039;4&amp;#039;&amp;#039;&amp;#039; 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 ma...&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;==Cerința==&lt;br /&gt;
&lt;br /&gt;
Se consideră o clădire de formă dreptunghiulară, împărțită în &amp;#039;&amp;#039;&amp;#039;n*m&amp;#039;&amp;#039;&amp;#039; camere, dispuse sub forma unei matrice cu &amp;#039;&amp;#039;&amp;#039;n&amp;#039;&amp;#039;&amp;#039; linii și &amp;#039;&amp;#039;&amp;#039;m&amp;#039;&amp;#039;&amp;#039; coloane. Dintr-o cameră se poate trece în oricare dintre cele &amp;#039;&amp;#039;&amp;#039;4&amp;#039;&amp;#039;&amp;#039; 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.&lt;br /&gt;
&lt;br /&gt;
Î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ă.&lt;br /&gt;
&lt;br /&gt;
==Date de intrare==&lt;br /&gt;
&lt;br /&gt;
Fișierul de intrare &amp;#039;&amp;#039;&amp;#039;acces1in.txt&amp;#039;&amp;#039;&amp;#039; conține pe prima linie numerele &amp;#039;&amp;#039;&amp;#039;n m&amp;#039;&amp;#039;&amp;#039;; următoarele &amp;#039;&amp;#039;&amp;#039;n&amp;#039;&amp;#039;&amp;#039; linii conțin câte &amp;#039;&amp;#039;&amp;#039;m&amp;#039;&amp;#039;&amp;#039; caractere, care pot fi:&lt;br /&gt;
&lt;br /&gt;
*&amp;#039;&amp;#039;&amp;#039;-&amp;#039;&amp;#039;&amp;#039; – reprezintă o cameră liberă&lt;br /&gt;
*&amp;#039;&amp;#039;&amp;#039;#&amp;#039;&amp;#039;&amp;#039; – reprezintă o cameră închisă&lt;br /&gt;
*&amp;#039;&amp;#039;&amp;#039;P&amp;#039;&amp;#039;&amp;#039; – reprezintă o cameră în care se găsește o echipă de pompieri&lt;br /&gt;
&lt;br /&gt;
==Date de ieșire==&lt;br /&gt;
&lt;br /&gt;
Fișierul de ieșire &amp;#039;&amp;#039;&amp;#039;acces1out.txt&amp;#039;&amp;#039;&amp;#039; va conține o matrice cu &amp;#039;&amp;#039;&amp;#039;n&amp;#039;&amp;#039;&amp;#039; linii și &amp;#039;&amp;#039;&amp;#039;m&amp;#039;&amp;#039;&amp;#039; 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 &amp;#039;&amp;#039;&amp;#039;#&amp;#039;&amp;#039;&amp;#039;, iar pentru cele libere în care nu va ajunge nici o echipă se va afișa &amp;#039;&amp;#039;&amp;#039;-&amp;#039;&amp;#039;&amp;#039;.&lt;br /&gt;
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.&lt;br /&gt;
&lt;br /&gt;
==Restricții și precizări==&lt;br /&gt;
&lt;br /&gt;
*&amp;#039;&amp;#039;&amp;#039;1 ≤ n,m ≤ 1000&lt;br /&gt;
&lt;br /&gt;
==Exemplul 1:==&lt;br /&gt;
&lt;br /&gt;
&amp;#039;&amp;#039;&amp;#039;acces1in.txt&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
&lt;br /&gt;
 4 6&lt;br /&gt;
 P-#-#P&lt;br /&gt;
 --##--&lt;br /&gt;
 --P---&lt;br /&gt;
 -----#&lt;br /&gt;
&lt;br /&gt;
&amp;#039;&amp;#039;&amp;#039;acces1out.txt&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
&lt;br /&gt;
 Datele de intrare corespund restrictiilor impuse&lt;br /&gt;
 0 1 # - # 0 &lt;br /&gt;
 1 2 # # 2 1 &lt;br /&gt;
 2 1 0 1 2 2 &lt;br /&gt;
 3 2 1 2 3 # &lt;br /&gt;
&lt;br /&gt;
==Exemplul 2:==&lt;br /&gt;
&lt;br /&gt;
&amp;#039;&amp;#039;&amp;#039;acces1in.txt&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
&lt;br /&gt;
 acces1&lt;br /&gt;
&lt;br /&gt;
&amp;#039;&amp;#039;&amp;#039;acces1out.txt&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
&lt;br /&gt;
 Datele de intrare nu corespund restrictiilor impuse&lt;br /&gt;
&lt;br /&gt;
==Rezolvare==&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;python&amp;quot; line=&amp;quot;1&amp;quot; start=&amp;quot;1&amp;quot;&amp;gt;&lt;br /&gt;
&lt;br /&gt;
from collections import deque&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
def validare(n_linii, m_coloane, matrice):&lt;br /&gt;
    if n_linii &amp;gt; 1000 or m_coloane &amp;gt; 1000:&lt;br /&gt;
        raise ValueError&lt;br /&gt;
    for linie in matrice:&lt;br /&gt;
        for caracter in linie:&lt;br /&gt;
            if caracter not in [&amp;#039;-&amp;#039;, &amp;#039;#&amp;#039;, &amp;#039;P&amp;#039;]:&lt;br /&gt;
                raise ValueError&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
def bfs(n_linii, m_coloane, matrice):&lt;br /&gt;
    dx = [-1, 0, 1, 0]&lt;br /&gt;
    dy = [0, 1, 0, -1]&lt;br /&gt;
    distanta = [[-1] * m_coloane for _ in range(n_linii)]&lt;br /&gt;
    q = deque()&lt;br /&gt;
&lt;br /&gt;
    for nr_i in range(n_linii):&lt;br /&gt;
        for nr_j in range(m_coloane):&lt;br /&gt;
            if matrice[nr_i][nr_j] == &amp;#039;P&amp;#039;:&lt;br /&gt;
                q.append((nr_i, nr_j))&lt;br /&gt;
                distanta[nr_i][nr_j] = 0&lt;br /&gt;
&lt;br /&gt;
    while q:&lt;br /&gt;
        x, y = q.popleft()&lt;br /&gt;
        for directie in range(4):&lt;br /&gt;
            nx, ny = x + dx[directie], y + dy[directie]&lt;br /&gt;
            if 0 &amp;lt;= nx &amp;lt; n_linii and 0 &amp;lt;= ny &amp;lt; m_coloane and matrice[nx][ny] != &amp;#039;#&amp;#039; and distanta[nx][ny] == -1:&lt;br /&gt;
                distanta[nx][ny] = distanta[x][y] + 1&lt;br /&gt;
                q.append((nx, ny))&lt;br /&gt;
&lt;br /&gt;
    return distanta&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
if __name__ == &amp;#039;__main__&amp;#039;:&lt;br /&gt;
    file_in = open(&amp;quot;acces1in.txt&amp;quot;, &amp;quot;r&amp;quot;)&lt;br /&gt;
    file_out = open(&amp;quot;acces1out.txt&amp;quot;, &amp;quot;w&amp;quot;)&lt;br /&gt;
&lt;br /&gt;
    try:&lt;br /&gt;
        n, m = map(int, file_in.readline().split())&lt;br /&gt;
        mat = [list(file_in.readline().strip()) for _ in range(n)]&lt;br /&gt;
&lt;br /&gt;
        validare(n, m, mat)&lt;br /&gt;
        file_out.write(&amp;quot;Datele de intrare corespund restrictiilor impuse\n&amp;quot;)&lt;br /&gt;
        dist = bfs(n, m, mat)&lt;br /&gt;
&lt;br /&gt;
        for i in range(n):&lt;br /&gt;
            for j in range(m):&lt;br /&gt;
                if mat[i][j] == &amp;#039;#&amp;#039;:&lt;br /&gt;
                    file_out.write(&amp;#039;# &amp;#039;)&lt;br /&gt;
                elif dist[i][j] == -1:&lt;br /&gt;
                    file_out.write(&amp;#039;- &amp;#039;)&lt;br /&gt;
                else:&lt;br /&gt;
                    file_out.write(str(dist[i][j]) + &amp;#039; &amp;#039;)&lt;br /&gt;
            file_out.write(&amp;#039;\n&amp;#039;)&lt;br /&gt;
&lt;br /&gt;
    except ValueError:&lt;br /&gt;
        file_out.write(&amp;quot;Datele de intrare nu corespund restrictiilor impuse&amp;quot;)&lt;br /&gt;
&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;/div&gt;</summary>
		<author><name>Bonte Lucas Gabriel</name></author>
	</entry>
</feed>