<?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=1238_-_Labirint</id>
	<title>1238 - Labirint - Revision history</title>
	<link rel="self" type="application/atom+xml" href="https://wiki.universitas.ro/index.php?action=history&amp;feed=atom&amp;title=1238_-_Labirint"/>
	<link rel="alternate" type="text/html" href="https://wiki.universitas.ro/index.php?title=1238_-_Labirint&amp;action=history"/>
	<updated>2026-05-02T13:19:50Z</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=1238_-_Labirint&amp;diff=8280&amp;oldid=prev</id>
		<title>Raul: /* Lipește codul aici */</title>
		<link rel="alternate" type="text/html" href="https://wiki.universitas.ro/index.php?title=1238_-_Labirint&amp;diff=8280&amp;oldid=prev"/>
		<updated>2023-12-21T16:09:34Z</updated>

		<summary type="html">&lt;p&gt;&lt;span dir=&quot;auto&quot;&gt;&lt;span class=&quot;autocomment&quot;&gt;Lipește codul aici&lt;/span&gt;&lt;/span&gt;&lt;/p&gt;
&lt;table style=&quot;background-color: #fff; color: #202122;&quot; data-mw=&quot;interface&quot;&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;tr class=&quot;diff-title&quot; lang=&quot;en&quot;&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;← Older revision&lt;/td&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;Revision as of 16:09, 21 December 2023&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot; id=&quot;mw-diff-left-l40&quot;&gt;Line 40:&lt;/td&gt;
&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot;&gt;Line 40:&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;import queue&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;import queue&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;−&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;fin = open(&quot;labirint.&lt;del style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;txtin&lt;/del&gt;&quot;, &quot;r&quot;)&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;+&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;fin = open(&quot;labirint.&lt;ins style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;in&lt;/ins&gt;&quot;, &quot;r&quot;)&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;−&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;fout = open(&quot;labirint.&lt;del style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;txtout&lt;/del&gt;&quot;, &quot;w&quot;)&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;+&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;fout = open(&quot;labirint.&lt;ins style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;out&lt;/ins&gt;&quot;, &quot;w&quot;)&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;N = 1005&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;N = 1005&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;dx = [-1, 0, 1, 0]&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;dx = [-1, 0, 1, 0]&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;/table&gt;</summary>
		<author><name>Raul</name></author>
	</entry>
	<entry>
		<id>https://wiki.universitas.ro/index.php?title=1238_-_Labirint&amp;diff=8279&amp;oldid=prev</id>
		<title>Raul: Pagină nouă:  = Cerința = Zoli și D’Umbră s-au pierdut într-un labirint cu &lt;code&gt;n x n&lt;/code&gt; camere dispuse pe cate &lt;code&gt;n&lt;/code&gt; linii și &lt;code&gt;n&lt;/code&gt; coloane. D’umbră se află în camera &lt;code&gt;(1, 1)&lt;/code&gt;, iar Zoli se află în camera &lt;code&gt;(n, n)&lt;/code&gt;. Aceștia vor trebui să parcurgă labirintul pentru a se regăsi. Dacă unul dintre ei se aflâ în camera &lt;code&gt;(i, j)&lt;/code&gt;, acesta se poate deplasa spre una din camerele aflate la pozițiile &lt;code&gt;(i + 1, j)&lt;/code&gt;,...</title>
		<link rel="alternate" type="text/html" href="https://wiki.universitas.ro/index.php?title=1238_-_Labirint&amp;diff=8279&amp;oldid=prev"/>
		<updated>2023-12-21T16:09:10Z</updated>

		<summary type="html">&lt;p&gt;Pagină nouă:  = Cerința = Zoli și D’Umbră s-au pierdut într-un labirint cu &amp;lt;code&amp;gt;n x n&amp;lt;/code&amp;gt; camere dispuse pe cate &amp;lt;code&amp;gt;n&amp;lt;/code&amp;gt; linii și &amp;lt;code&amp;gt;n&amp;lt;/code&amp;gt; coloane. D’umbră se află în camera &amp;lt;code&amp;gt;(1, 1)&amp;lt;/code&amp;gt;, iar Zoli se află în camera &amp;lt;code&amp;gt;(n, n)&amp;lt;/code&amp;gt;. Aceștia vor trebui să parcurgă labirintul pentru a se regăsi. Dacă unul dintre ei se aflâ în camera &amp;lt;code&amp;gt;(i, j)&amp;lt;/code&amp;gt;, acesta se poate deplasa spre una din camerele aflate la pozițiile &amp;lt;code&amp;gt;(i + 1, j)&amp;lt;/code&amp;gt;,...&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;&lt;br /&gt;
= Cerința =&lt;br /&gt;
Zoli și D’Umbră s-au pierdut într-un labirint cu &amp;lt;code&amp;gt;n x n&amp;lt;/code&amp;gt; camere dispuse pe cate &amp;lt;code&amp;gt;n&amp;lt;/code&amp;gt; linii și &amp;lt;code&amp;gt;n&amp;lt;/code&amp;gt; coloane. D’umbră se află în camera &amp;lt;code&amp;gt;(1, 1)&amp;lt;/code&amp;gt;, iar Zoli se află în camera &amp;lt;code&amp;gt;(n, n)&amp;lt;/code&amp;gt;. Aceștia vor trebui să parcurgă labirintul pentru a se regăsi. Dacă unul dintre ei se aflâ în camera &amp;lt;code&amp;gt;(i, j)&amp;lt;/code&amp;gt;, acesta se poate deplasa spre una din camerele aflate la pozițiile &amp;lt;code&amp;gt;(i + 1, j)&amp;lt;/code&amp;gt;, &amp;lt;code&amp;gt;(i, j + 1)&amp;lt;/code&amp;gt;, &amp;lt;code&amp;gt;(i - 1, j)&amp;lt;/code&amp;gt; sau &amp;lt;code&amp;gt;(i, j - 1)&amp;lt;/code&amp;gt;, fără a părăsi labirintul.&lt;br /&gt;
&lt;br /&gt;
Camerele nu pot fi accesate ușor. La fiecare cameră se află câte o ușă având o rezistență &amp;lt;code&amp;gt;R&amp;lt;/code&amp;gt; care poate fi spartă cu un baros cu o putere &amp;lt;code&amp;gt;P ≥ R&amp;lt;/code&amp;gt;. Unul dintre cei doi (nu contează care) va avea acces la un arsenal de barosuri cu puteri între &amp;lt;code&amp;gt;0&amp;lt;/code&amp;gt; și &amp;lt;code&amp;gt;100.000&amp;lt;/code&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
Determinați puterea minimă pe care o poate avea barosul ce trebuie folosit astfel încât Zoli și D’Umbră să se poată întâlni.&lt;br /&gt;
&lt;br /&gt;
= Date de intrare =&lt;br /&gt;
Fișierul de intrare &amp;lt;code&amp;gt;labirint.in&amp;lt;/code&amp;gt; conține pe prima linie numărul &amp;lt;code&amp;gt;n&amp;lt;/code&amp;gt;, iar pe următoarele &amp;lt;code&amp;gt;n&amp;lt;/code&amp;gt; linii &amp;lt;code&amp;gt;n&amp;lt;/code&amp;gt; numere, al &amp;lt;code&amp;gt;j&amp;lt;/code&amp;gt; -lea număr de pe linia &amp;lt;code&amp;gt;i + 1&amp;lt;/code&amp;gt; reprezintă rezistența ușii de la camera aflată în &amp;lt;code&amp;gt;(i, j)&amp;lt;/code&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
= Date de ieșire =&lt;br /&gt;
Fișierul de ieșire &amp;lt;code&amp;gt;labirint.out&amp;lt;/code&amp;gt; va conține pe prima linie numărul &amp;lt;code&amp;gt;Pmin&amp;lt;/code&amp;gt;, reprezentând puterea minimă pe care o poate avea un baros folosit pentru a sparge anumite uși și a conecta camerele &amp;lt;code&amp;gt;(1, 1)&amp;lt;/code&amp;gt; și &amp;lt;code&amp;gt;(n, n)&amp;lt;/code&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
= Restricții și precizări =&lt;br /&gt;
&lt;br /&gt;
* &amp;lt;code&amp;gt;1 ≤ n ≤ 1.000&amp;lt;/code&amp;gt;&lt;br /&gt;
* &amp;lt;code&amp;gt;0 ≤&amp;lt;/code&amp;gt; rezistența unei uși &amp;lt;code&amp;gt;≤ 100.000&amp;lt;/code&amp;gt;&lt;br /&gt;
* pentru &amp;lt;code&amp;gt;50%&amp;lt;/code&amp;gt; din punctaj, &amp;lt;code&amp;gt;Pmin ≤ 600&amp;lt;/code&amp;gt; și &amp;lt;code&amp;gt;n ≤ 500&amp;lt;/code&amp;gt;&lt;br /&gt;
&lt;br /&gt;
= Exemplu: =&lt;br /&gt;
&amp;lt;code&amp;gt;labirint.in&amp;lt;/code&amp;gt;&lt;br /&gt;
 4&lt;br /&gt;
 1 2 3 4 &lt;br /&gt;
 2 3 1 4 &lt;br /&gt;
 2 1 2 3&lt;br /&gt;
 3 3 1 1 &lt;br /&gt;
&amp;lt;code&amp;gt;labirint.out&amp;lt;/code&amp;gt;&lt;br /&gt;
 2&lt;br /&gt;
&lt;br /&gt;
=== Explicație ===&lt;br /&gt;
&amp;lt;code&amp;gt;(1, 1) -&amp;gt; (2, 1) -&amp;gt; (3, 1) -&amp;gt; (3, 2) -&amp;gt; (3, 3) -&amp;gt; (4, 3) -&amp;gt; (4, 4)&amp;lt;/code&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Se evită camerele cu rezistență mai mare decât &amp;lt;code&amp;gt;2&amp;lt;/code&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
== Încărcare soluție ==&lt;br /&gt;
&lt;br /&gt;
=== Lipește codul aici ===&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;python&amp;quot; line=&amp;quot;1&amp;quot;&amp;gt;&lt;br /&gt;
import queue&lt;br /&gt;
&lt;br /&gt;
fin = open(&amp;quot;labirint.txtin&amp;quot;, &amp;quot;r&amp;quot;)&lt;br /&gt;
fout = open(&amp;quot;labirint.txtout&amp;quot;, &amp;quot;w&amp;quot;)&lt;br /&gt;
N = 1005&lt;br /&gt;
dx = [-1, 0, 1, 0]&lt;br /&gt;
dy = [0, 1, 0, -1]&lt;br /&gt;
a = [[0] * N for _ in range(N)]&lt;br /&gt;
v = [[0] * N for _ in range(N)]&lt;br /&gt;
n = 0&lt;br /&gt;
sol = 0&lt;br /&gt;
step = 1 &amp;lt;&amp;lt; 16&lt;br /&gt;
Q = queue.Queue()&lt;br /&gt;
&lt;br /&gt;
def lee(k):&lt;br /&gt;
    global Q&lt;br /&gt;
    global v&lt;br /&gt;
    global n&lt;br /&gt;
    global a&lt;br /&gt;
    for i in range(1, n + 1):&lt;br /&gt;
        for j in range(1, n + 1):&lt;br /&gt;
            v[i][j] = 0&lt;br /&gt;
    if a[1][1] &amp;lt;= k:&lt;br /&gt;
        Q.put((1, 1))&lt;br /&gt;
    else:&lt;br /&gt;
        return 0&lt;br /&gt;
    while not Q.empty() and not v[n][n]:&lt;br /&gt;
        x, y = Q.get()&lt;br /&gt;
        for crt in range(4):&lt;br /&gt;
            xx = x + dx[crt]&lt;br /&gt;
            yy = y + dy[crt]&lt;br /&gt;
            if not v[xx][yy] and a[xx][yy] &amp;lt;= k:&lt;br /&gt;
                v[xx][yy] = 1&lt;br /&gt;
                Q.put((xx, yy))&lt;br /&gt;
    while not Q.empty():&lt;br /&gt;
        Q.get()&lt;br /&gt;
    return v[n][n]&lt;br /&gt;
&lt;br /&gt;
n = int(fin.readline())&lt;br /&gt;
for i in range(1, n + 1):&lt;br /&gt;
    a[i] = list(map(int, fin.readline().split()))&lt;br /&gt;
for i in range(n + 2):&lt;br /&gt;
    for j in range(n + 2):&lt;br /&gt;
        v[i][j] = 1&lt;br /&gt;
while step:&lt;br /&gt;
    if not lee(sol + step):&lt;br /&gt;
        sol += step&lt;br /&gt;
    step &amp;gt;&amp;gt;= 1&lt;br /&gt;
fout.write(str(sol + 1))&lt;br /&gt;
fin.close()&lt;br /&gt;
fout.close()&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;/div&gt;</summary>
		<author><name>Raul</name></author>
	</entry>
</feed>