<?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=0864_-_Roboti</id>
	<title>0864 - Roboti - Revision history</title>
	<link rel="self" type="application/atom+xml" href="https://wiki.universitas.ro/index.php?action=history&amp;feed=atom&amp;title=0864_-_Roboti"/>
	<link rel="alternate" type="text/html" href="https://wiki.universitas.ro/index.php?title=0864_-_Roboti&amp;action=history"/>
	<updated>2026-05-01T07:40:57Z</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=0864_-_Roboti&amp;diff=7426&amp;oldid=prev</id>
		<title>Bonte Lucas Gabriel at 18:08, 17 November 2023</title>
		<link rel="alternate" type="text/html" href="https://wiki.universitas.ro/index.php?title=0864_-_Roboti&amp;diff=7426&amp;oldid=prev"/>
		<updated>2023-11-17T18:08:00Z</updated>

		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;a href=&quot;//wiki.universitas.ro/index.php?title=0864_-_Roboti&amp;amp;diff=7426&amp;amp;oldid=7180&quot;&gt;Show changes&lt;/a&gt;</summary>
		<author><name>Bonte Lucas Gabriel</name></author>
	</entry>
	<entry>
		<id>https://wiki.universitas.ro/index.php?title=0864_-_Roboti&amp;diff=7180&amp;oldid=prev</id>
		<title>Bonte Lucas Gabriel: Pagină nouă: ==Cerința==  Se dă o matrice cu &#039;&#039;&#039;n&#039;&#039;&#039; linii și &#039;&#039;&#039;m&#039;&#039;&#039; coloane și elemente &#039;&#039;&#039;0&#039;&#039;&#039; sau &#039;&#039;&#039;1&#039;&#039;&#039;, reprezentând planul unui teren în care &#039;&#039;&#039;0&#039;&#039;&#039; reprezintă o zonă accesibilă, iar &#039;&#039;&#039;1&#039;&#039;&#039; reprezintă o zonă inaccesibilă. O zonă a terenului are ca și coordonate linia și coloana corespunzătoare din matrice. Într-o zonă cunoscută a matricei se află un robot, iar în altă zonă, de asemenea cunoscută, se află o roboțică. Determinați numărul minim de pași...</title>
		<link rel="alternate" type="text/html" href="https://wiki.universitas.ro/index.php?title=0864_-_Roboti&amp;diff=7180&amp;oldid=prev"/>
		<updated>2023-11-08T23:28:29Z</updated>

		<summary type="html">&lt;p&gt;Pagină nouă: ==Cerința==  Se dă 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 și elemente &amp;#039;&amp;#039;&amp;#039;0&amp;#039;&amp;#039;&amp;#039; sau &amp;#039;&amp;#039;&amp;#039;1&amp;#039;&amp;#039;&amp;#039;, reprezentând planul unui teren în care &amp;#039;&amp;#039;&amp;#039;0&amp;#039;&amp;#039;&amp;#039; reprezintă o zonă accesibilă, iar &amp;#039;&amp;#039;&amp;#039;1&amp;#039;&amp;#039;&amp;#039; reprezintă o zonă inaccesibilă. O zonă a terenului are ca și coordonate linia și coloana corespunzătoare din matrice. Într-o zonă cunoscută a matricei se află un robot, iar în altă zonă, de asemenea cunoscută, se află o roboțică. Determinați numărul minim de pași...&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 dă 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 și elemente &amp;#039;&amp;#039;&amp;#039;0&amp;#039;&amp;#039;&amp;#039; sau &amp;#039;&amp;#039;&amp;#039;1&amp;#039;&amp;#039;&amp;#039;, reprezentând planul unui teren în care &amp;#039;&amp;#039;&amp;#039;0&amp;#039;&amp;#039;&amp;#039; reprezintă o zonă accesibilă, iar &amp;#039;&amp;#039;&amp;#039;1&amp;#039;&amp;#039;&amp;#039; reprezintă o zonă inaccesibilă. O zonă a terenului are ca și coordonate linia și coloana corespunzătoare din matrice. Într-o zonă cunoscută a matricei se află un robot, iar în altă zonă, de asemenea cunoscută, se află o roboțică. Determinați numărul minim de pași prin care robotul va ajunge la roboțică. Dacă nu este posibil ca robotul să ajungă la roboțică, rezultatul va fi &amp;#039;&amp;#039;&amp;#039;-1&amp;#039;&amp;#039;&amp;#039;.&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;roboti.in&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; valori, &amp;#039;&amp;#039;&amp;#039;0&amp;#039;&amp;#039;&amp;#039; sau &amp;#039;&amp;#039;&amp;#039;1&amp;#039;&amp;#039;&amp;#039;. Următoarele două linii conțin câte două valori, reprezentând coordonatele robotului, respectiv ale roboțicii.&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;roboti.out&amp;#039;&amp;#039;&amp;#039; va conține pe prima linie valoarea cerută.&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;
*zonele pe care se află inițial cei doi roboți sunt libere și sunt diferite&lt;br /&gt;
*un pas reprezintă trecerea robotului din zona curentă într-o zonă vecină cu aceasta pe linie sau pe coloană, fără a părăsi matricea.&lt;br /&gt;
&lt;br /&gt;
==Exemplu:==&lt;br /&gt;
&lt;br /&gt;
;roboti.in&lt;br /&gt;
&lt;br /&gt;
:4 5&lt;br /&gt;
:1 0 0 0 1&lt;br /&gt;
:0 0 1 0 0&lt;br /&gt;
:0 0 0 0 1&lt;br /&gt;
:1 1 0 0 1&lt;br /&gt;
:1 2&lt;br /&gt;
:2 5&lt;br /&gt;
&lt;br /&gt;
;roboti.out&lt;br /&gt;
&lt;br /&gt;
:4&lt;br /&gt;
&lt;br /&gt;
==Explicație==&lt;br /&gt;
&lt;br /&gt;
Un traseu al robotului format din &amp;#039;&amp;#039;&amp;#039;4&amp;#039;&amp;#039;&amp;#039; pași este evidențiat mai jos.&lt;br /&gt;
&lt;br /&gt;
1	&amp;#039;&amp;#039;&amp;#039;0	0	0&amp;#039;&amp;#039;&amp;#039;	1&lt;br /&gt;
0	0	1	&amp;#039;&amp;#039;&amp;#039;0	0&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
0	0	0	0	1&lt;br /&gt;
1	1	0	0	1&lt;br /&gt;
Există și alte trasee posibile, dar lungimea lor este mai mare.&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;
def citire():&lt;br /&gt;
    # Deschidem fișierul de intrare și citim datele&lt;br /&gt;
    with open(&amp;#039;roboti.in&amp;#039;, &amp;#039;r&amp;#039;) as f:&lt;br /&gt;
        n, m = map(int, f.readline().split())  # Citim numărul de linii și coloane&lt;br /&gt;
        matrice = [list(map(int, f.readline().split())) for _ in range(n)]  # Citim matricea&lt;br /&gt;
        x_start, y_start = map(int, f.readline().split())  # Citim coordonatele robotului&lt;br /&gt;
        x_end, y_end = map(int, f.readline().split())  # Citim coordonatele roboțicii&lt;br /&gt;
    # Returnăm toate datele citite&lt;br /&gt;
    return n, m, matrice, x_start-1, y_start-1, x_end-1, y_end-1&lt;br /&gt;
&lt;br /&gt;
def valid(i, j, n, m):&lt;br /&gt;
    # Verificăm dacă o poziție este validă (adică se află în interiorul matricei)&lt;br /&gt;
    return 0 &amp;lt;= i &amp;lt; n and 0 &amp;lt;= j &amp;lt; m&lt;br /&gt;
&lt;br /&gt;
def bfs(x_start, y_start, x_end, y_end, n, m, matrice):&lt;br /&gt;
    # Inițializăm direcțiile în care se poate deplasa robotul&lt;br /&gt;
    dx = [-1, 0, 1, 0]&lt;br /&gt;
    dy = [0, 1, 0, -1]&lt;br /&gt;
    # Inițializăm matricea de distanțe cu -1&lt;br /&gt;
    distanta = [[-1 for _ in range(m)] for _ in range(n)]&lt;br /&gt;
    # Inițializăm coada pentru BFS și adăugăm poziția de start&lt;br /&gt;
    coada = deque()&lt;br /&gt;
    coada.append((x_start, y_start))&lt;br /&gt;
    distanta[x_start][y_start] = 0&lt;br /&gt;
    # Parcurgem toate pozițiile din coadă&lt;br /&gt;
    while coada:&lt;br /&gt;
        x, y = coada.popleft()&lt;br /&gt;
        # Încercăm toate direcțiile posibile de deplasare&lt;br /&gt;
        for directie in range(4):&lt;br /&gt;
            new_x, new_y = x + dx[directie], y + dy[directie]&lt;br /&gt;
            # Dacă poziția este validă, liberă și nu a fost vizitată încă, o adăugăm în coadă&lt;br /&gt;
            if valid(new_x, new_y, n, m) and matrice[new_x][new_y] == 0 and distanta[new_x][new_y] == -1:&lt;br /&gt;
                coada.append((new_x, new_y))&lt;br /&gt;
                distanta[new_x][new_y] = distanta[x][y] + 1&lt;br /&gt;
    # Returnăm distanța de la robot la roboțică&lt;br /&gt;
    return distanta[x_end][y_end]&lt;br /&gt;
&lt;br /&gt;
def scriere(rezultat):&lt;br /&gt;
    # Scriem rezultatul în fișierul de ieșire&lt;br /&gt;
    with open(&amp;#039;roboti.out&amp;#039;, &amp;#039;w&amp;#039;) as f:&lt;br /&gt;
        f.write(str(rezultat))&lt;br /&gt;
&lt;br /&gt;
def main():&lt;br /&gt;
    # Citim datele de intrare&lt;br /&gt;
    n, m, matrice, x_start, y_start, x_end, y_end = citire()&lt;br /&gt;
    # Calculăm rezultatul&lt;br /&gt;
    rezultat = bfs(x_start, y_start, x_end, y_end, n, m, matrice)&lt;br /&gt;
    # Scriem rezultatul în fișierul de ieșire&lt;br /&gt;
    scriere(rezultat)&lt;br /&gt;
&lt;br /&gt;
if __name__ == &amp;quot;__main__&amp;quot;:&lt;br /&gt;
    main()&lt;br /&gt;
&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;/div&gt;</summary>
		<author><name>Bonte Lucas Gabriel</name></author>
	</entry>
</feed>