<?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=0866_-_Acces</id>
	<title>0866 - Acces - Revision history</title>
	<link rel="self" type="application/atom+xml" href="https://wiki.universitas.ro/index.php?action=history&amp;feed=atom&amp;title=0866_-_Acces"/>
	<link rel="alternate" type="text/html" href="https://wiki.universitas.ro/index.php?title=0866_-_Acces&amp;action=history"/>
	<updated>2026-05-01T07:45:16Z</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=0866_-_Acces&amp;diff=7604&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 una dintre camere se află proprietarul clădirii, care dorește să afle...</title>
		<link rel="alternate" type="text/html" href="https://wiki.universitas.ro/index.php?title=0866_-_Acces&amp;diff=7604&amp;oldid=prev"/>
		<updated>2023-12-03T22:11:28Z</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 una dintre camere se află proprietarul clădirii, care dorește să afle...&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 una dintre camere se află proprietarul clădirii, care dorește să afle, pentru fiecare dintre camere care este timpul minim necesar pentru a 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;accesin.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ă camera proprietarului, care se consideră liberă&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;accesout.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, elementele matricei reprezentând timpul minim necesar ca proprietarul să ajungă în camere clădirii. Pentru camerele ocupate și pentru camerele libere în care nu se poate ajunge timpul necesar va fi &amp;#039;&amp;#039;&amp;#039;-1&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&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
&lt;br /&gt;
==Exemplul 1:==&lt;br /&gt;
&lt;br /&gt;
&amp;#039;&amp;#039;&amp;#039;accesin.txt&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
&lt;br /&gt;
 4 6&lt;br /&gt;
 --#-#-&lt;br /&gt;
 --##--&lt;br /&gt;
 --P---&lt;br /&gt;
 -----#&lt;br /&gt;
&lt;br /&gt;
&amp;#039;&amp;#039;&amp;#039;accesout.txt&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
&lt;br /&gt;
 Datele de intrare corespund restrictiilor impuse&lt;br /&gt;
 4 3 -1 -1 -1 5 &lt;br /&gt;
 3 2 -1 -1 3 4 &lt;br /&gt;
 2 1 0 1 2 3 &lt;br /&gt;
 3 2 1 2 3 -1 &lt;br /&gt;
&lt;br /&gt;
==Exemplul 2:==&lt;br /&gt;
&lt;br /&gt;
&amp;#039;&amp;#039;&amp;#039;accesin.txt&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
&lt;br /&gt;
 acces&lt;br /&gt;
&lt;br /&gt;
&amp;#039;&amp;#039;&amp;#039;accesout.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):  # functia de validare a datelor de intrare&lt;br /&gt;
    if n_linii &amp;gt; 1000 or m_coloane &amp;gt; 1000:&lt;br /&gt;
        raise ValueError&lt;br /&gt;
&lt;br /&gt;
    for linie in matrice:&lt;br /&gt;
        if len(linie) != m_coloane:  # fiecare linie trebuie sa aiba lungimea m&lt;br /&gt;
            raise ValueError&lt;br /&gt;
&lt;br /&gt;
    file_out.write(&amp;quot;Datele de intrare corespund restrictiilor impuse\n&amp;quot;)&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
def acces(nr, nc, matrice):  # functia de rezolvare&lt;br /&gt;
    dx = [-1, 0, 1, 0]&lt;br /&gt;
    dy = [0, 1, 0, -1]&lt;br /&gt;
    dist = [[-1]*nc for _ in range(nr)]&lt;br /&gt;
    q = deque()&lt;br /&gt;
&lt;br /&gt;
    for i in range(nr):&lt;br /&gt;
        for j in range(nc):&lt;br /&gt;
            if matrice[i][j] == &amp;#039;P&amp;#039;:&lt;br /&gt;
                q.append((i, j))&lt;br /&gt;
                dist[i][j] = 0&lt;br /&gt;
&lt;br /&gt;
    while q:&lt;br /&gt;
        x, y = q.popleft()&lt;br /&gt;
        for d in range(4):&lt;br /&gt;
            nx, ny = x + dx[d], y + dy[d]&lt;br /&gt;
            if 0 &amp;lt;= nx &amp;lt; nr and 0 &amp;lt;= ny &amp;lt; nc and matrice[nx][ny] != &amp;#039;#&amp;#039; and dist[nx][ny] == -1:&lt;br /&gt;
                dist[nx][ny] = dist[x][y] + 1&lt;br /&gt;
                q.append((nx, ny))&lt;br /&gt;
&lt;br /&gt;
    for i in range(nr):&lt;br /&gt;
        for j in range(nc):&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;
&lt;br /&gt;
if __name__ == &amp;#039;__main__&amp;#039;:&lt;br /&gt;
    file_in = open(&amp;quot;accesin.txt&amp;quot;, &amp;quot;r&amp;quot;)  # declararea fisierelor&lt;br /&gt;
    file_out = open(&amp;quot;accesout.txt&amp;quot;, &amp;quot;w&amp;quot;)  # fisierul out trebuie declarat cu optiunea &amp;quot;w&amp;quot; (write)&lt;br /&gt;
&lt;br /&gt;
    # din cauza datelor de intrare pot aparea 2 tipuri de erori, valueError sau IndexError pe care le tratam&lt;br /&gt;
    try:&lt;br /&gt;
        n, m = map(int, file_in.readline().split())  # citirea numarului de linii si coloane&lt;br /&gt;
        mat = [list(file_in.readline().strip()) for _ in range(n)]  # citirea matricei&lt;br /&gt;
&lt;br /&gt;
        validare(n, m, mat)  # apelul functiei de validare&lt;br /&gt;
        acces(n, m, mat)  # apelul functiei de rezolvare&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;
    except IndexError:&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>