<?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=2164_-_munte1</id>
	<title>2164 - munte1 - Revision history</title>
	<link rel="self" type="application/atom+xml" href="https://wiki.universitas.ro/index.php?action=history&amp;feed=atom&amp;title=2164_-_munte1"/>
	<link rel="alternate" type="text/html" href="https://wiki.universitas.ro/index.php?title=2164_-_munte1&amp;action=history"/>
	<updated>2026-05-01T03:40:25Z</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=2164_-_munte1&amp;diff=9681&amp;oldid=prev</id>
		<title>Aurelia Raluca at 07:13, 24 February 2024</title>
		<link rel="alternate" type="text/html" href="https://wiki.universitas.ro/index.php?title=2164_-_munte1&amp;diff=9681&amp;oldid=prev"/>
		<updated>2024-02-24T07:13:28Z</updated>

		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;a href=&quot;//wiki.universitas.ro/index.php?title=2164_-_munte1&amp;amp;diff=9681&amp;amp;oldid=9315&quot;&gt;Show changes&lt;/a&gt;</summary>
		<author><name>Aurelia Raluca</name></author>
	</entry>
	<entry>
		<id>https://wiki.universitas.ro/index.php?title=2164_-_munte1&amp;diff=9315&amp;oldid=prev</id>
		<title>Aurelia Raluca: Pagină nouă: == Enunt ==  Maria pleacă în excursie la munte. Traseul de la baza muntelui și până la vârf trece printr-o serie de parcele organizate într-o matrice pătratică de dimensiune nxn. Baza muntelui se consideră primul element al matricei, iar vârful, ultimul element. Se cunoaște faptul că traseele de la bază până la vârf au numai suișuri. Maria dispune de un altimetru prin intermediul căruia poate determina altitudinea la care se găsește parcela pe care se afl...</title>
		<link rel="alternate" type="text/html" href="https://wiki.universitas.ro/index.php?title=2164_-_munte1&amp;diff=9315&amp;oldid=prev"/>
		<updated>2024-01-09T10:23:04Z</updated>

		<summary type="html">&lt;p&gt;Pagină nouă: == Enunt ==  Maria pleacă în excursie la munte. Traseul de la baza muntelui și până la vârf trece printr-o serie de parcele organizate într-o matrice pătratică de dimensiune nxn. Baza muntelui se consideră primul element al matricei, iar vârful, ultimul element. Se cunoaște faptul că traseele de la bază până la vârf au numai suișuri. Maria dispune de un altimetru prin intermediul căruia poate determina altitudinea la care se găsește parcela pe care se afl...&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;== Enunt ==&lt;br /&gt;
&lt;br /&gt;
Maria pleacă în excursie la munte. Traseul de la baza muntelui și până la vârf trece printr-o serie de parcele organizate într-o matrice pătratică de dimensiune nxn. Baza muntelui se consideră primul element al matricei, iar vârful, ultimul element. Se cunoaște faptul că traseele de la bază până la vârf au numai suișuri. Maria dispune de un altimetru prin intermediul căruia poate determina altitudinea la care se găsește parcela pe care se află. Ea nu-și propune să urce până la vârf, ci doar până la o anumită altitudine.&lt;br /&gt;
&lt;br /&gt;
== Cerinta ==&lt;br /&gt;
&lt;br /&gt;
Cunoscând valoarea n, harta de dimensiune nxn cu altitudinile precizate și x o valoare ce reprezintă altitudinea la care trebuie să ajungă Maria, se cere să se determine coordonatele parcelei cu altitudinea x.&lt;br /&gt;
&lt;br /&gt;
== Date de intrare ==&lt;br /&gt;
&lt;br /&gt;
Fișierul de intrare munte1.in conține:&lt;br /&gt;
n // nxn parcele&lt;br /&gt;
a[1,1] a[1,2]......... a[1,n] // a[i,j] &amp;lt; a[i,j+1] cu i=1,n și j=1,n-1&lt;br /&gt;
a[2,1] a[2,2]......... a[2,n] // a[i,j]&amp;lt;a[i+1,j] cu i=1,n-1 și j=1,n&lt;br /&gt;
………………….&lt;br /&gt;
a[n,1] a[n,2]......... a[n,n] //harta cu altitudinile parcelelor&lt;br /&gt;
x //altitudinea destinaţie&lt;br /&gt;
&lt;br /&gt;
== Date de iesire ==&lt;br /&gt;
&lt;br /&gt;
Fișierul de ieșire munte1.out va conține pe prima linie două valori i și j separate printr-un spațiu reprezentând coordonatele parcelei cu altitudinea x.&lt;br /&gt;
&lt;br /&gt;
== Restricții și precizări ==&lt;br /&gt;
&lt;br /&gt;
*1 ≤ n ≤ 700&lt;br /&gt;
*altitudinea x se află pe hartă&lt;br /&gt;
*valorile altitudinilor sunt unice și sunt numere naturale mai mici decât 2.000.000.000&lt;br /&gt;
&lt;br /&gt;
== Exemplul 1 ==&lt;br /&gt;
&lt;br /&gt;
;munte1in.txt&lt;br /&gt;
&lt;br /&gt;
:4&lt;br /&gt;
&lt;br /&gt;
:1 3 9 10&lt;br /&gt;
&lt;br /&gt;
:2 4 11 13&lt;br /&gt;
&lt;br /&gt;
:5 6 12 14&lt;br /&gt;
&lt;br /&gt;
:7 15 16 19&lt;br /&gt;
&lt;br /&gt;
:13&lt;br /&gt;
&lt;br /&gt;
;munte1out.txt&lt;br /&gt;
&lt;br /&gt;
:Datele introduse corespund restrictiilor impuse.&lt;br /&gt;
&lt;br /&gt;
:2 4&lt;br /&gt;
&lt;br /&gt;
== Exemplul 2 ==&lt;br /&gt;
&lt;br /&gt;
;munte1in.txt&lt;br /&gt;
&lt;br /&gt;
:0&lt;br /&gt;
&lt;br /&gt;
:-4 55 33 33&lt;br /&gt;
&lt;br /&gt;
:-2 -3 -4 -7&lt;br /&gt;
&lt;br /&gt;
:-92 39 44 0&lt;br /&gt;
&lt;br /&gt;
:-12&lt;br /&gt;
&lt;br /&gt;
;munte1out.txt&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;python3&amp;quot; line=&amp;quot;1&amp;quot;&amp;gt;&lt;br /&gt;
&lt;br /&gt;
def cautare_binară_parcurs(matrice, n, altitudine):&lt;br /&gt;
    stânga, dreapta = 0, n - 1&lt;br /&gt;
&lt;br /&gt;
    while stânga &amp;lt;= dreapta:&lt;br /&gt;
        mijloc = (stânga + dreapta) // 2&lt;br /&gt;
        if matrice[mijloc][0] &amp;lt;= altitudine &amp;lt;= matrice[mijloc][n - 1]:&lt;br /&gt;
            return mijloc&lt;br /&gt;
        elif altitudine &amp;lt; matrice[mijloc][0]:&lt;br /&gt;
            dreapta = mijloc - 1&lt;br /&gt;
        else:&lt;br /&gt;
            stânga = mijloc + 1&lt;br /&gt;
&lt;br /&gt;
    return -1  # Altitudinea nu a fost găsită pe nicio parcelă&lt;br /&gt;
&lt;br /&gt;
def cautare_binară_coordonate(matrice, linie, n, altitudine):&lt;br /&gt;
    sus, jos = 0, n - 1&lt;br /&gt;
&lt;br /&gt;
    while sus &amp;lt;= jos:&lt;br /&gt;
        mijloc = (sus + jos) // 2&lt;br /&gt;
        if matrice[linie][mijloc] == altitudine:&lt;br /&gt;
            return linie, mijloc&lt;br /&gt;
        elif altitudine &amp;lt; matrice[linie][mijloc]:&lt;br /&gt;
            jos = mijloc - 1&lt;br /&gt;
        else:&lt;br /&gt;
            sus = mijloc + 1&lt;br /&gt;
&lt;br /&gt;
    return -1, -1  # Coordonatele nu au fost găsite pentru altitudinea specificată&lt;br /&gt;
&lt;br /&gt;
def determinare_coordonate(matrice, n, altitudine):&lt;br /&gt;
    linie = cautare_binară_parcurs(matrice, n, altitudine)&lt;br /&gt;
    &lt;br /&gt;
    if linie != -1:&lt;br /&gt;
        coordonate = cautare_binară_coordonate(matrice, linie, n, altitudine)&lt;br /&gt;
        return coordonate&lt;br /&gt;
    else:&lt;br /&gt;
        return -1, -1&lt;br /&gt;
coordonate = determinare_coordonate(matrice, n, altitudine_cautata)&lt;br /&gt;
if coordonate == (-1, -1):&lt;br /&gt;
    print(f&amp;quot;Nu există o parcelă cu altitudinea {altitudine_cautata}.&amp;quot;)&lt;br /&gt;
else:&lt;br /&gt;
    print(f&amp;quot;Coordonatele parcelei cu altitudinea {altitudine_cautata}: {coordonate}&amp;quot;)&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;/div&gt;</summary>
		<author><name>Aurelia Raluca</name></author>
	</entry>
</feed>