<?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=1906_-_Memory_007</id>
	<title>1906 - Memory 007 - Revision history</title>
	<link rel="self" type="application/atom+xml" href="https://wiki.universitas.ro/index.php?action=history&amp;feed=atom&amp;title=1906_-_Memory_007"/>
	<link rel="alternate" type="text/html" href="https://wiki.universitas.ro/index.php?title=1906_-_Memory_007&amp;action=history"/>
	<updated>2026-05-03T04:19:43Z</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=1906_-_Memory_007&amp;diff=7735&amp;oldid=prev</id>
		<title>AntalKrisztian: Pagină nouă: == Cerinţa == Agentul 007 a uitat cifrul seifului în care păstra documentele, însă ştie cum poate fi aflat. Are nişte cartonaşe pe care sunt notate &#039;&#039;&#039;n&#039;&#039;&#039; numere naturale distincte din intervalul [ &#039;&#039;&#039;a,b&#039;&#039;&#039; ]. Mai are o listă cu &#039;&#039;&#039;m&#039;&#039;&#039; numere naturale distincte care reprezintă anumite poziţii din şirul ordonat crescător al numerelor de pe cartonaşe. Însumând numerele aflate pe poziţiile din listă se determină un număr natural care reprezintă cifrul sei...</title>
		<link rel="alternate" type="text/html" href="https://wiki.universitas.ro/index.php?title=1906_-_Memory_007&amp;diff=7735&amp;oldid=prev"/>
		<updated>2023-12-10T13:18:46Z</updated>

		<summary type="html">&lt;p&gt;Pagină nouă: == Cerinţa == Agentul 007 a uitat cifrul seifului în care păstra documentele, însă ştie cum poate fi aflat. Are nişte cartonaşe pe care sunt notate &amp;#039;&amp;#039;&amp;#039;n&amp;#039;&amp;#039;&amp;#039; numere naturale distincte din intervalul [ &amp;#039;&amp;#039;&amp;#039;a,b&amp;#039;&amp;#039;&amp;#039; ]. Mai are o listă cu &amp;#039;&amp;#039;&amp;#039;m&amp;#039;&amp;#039;&amp;#039; numere naturale distincte care reprezintă anumite poziţii din şirul ordonat crescător al numerelor de pe cartonaşe. Însumând numerele aflate pe poziţiile din listă se determină un număr natural care reprezintă cifrul sei...&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;
Agentul 007 a uitat cifrul seifului în care păstra documentele, însă ştie cum poate fi aflat. Are nişte cartonaşe pe care sunt notate &amp;#039;&amp;#039;&amp;#039;n&amp;#039;&amp;#039;&amp;#039; numere naturale distincte din intervalul [ &amp;#039;&amp;#039;&amp;#039;a,b&amp;#039;&amp;#039;&amp;#039; ]. Mai are o listă cu &amp;#039;&amp;#039;&amp;#039;m&amp;#039;&amp;#039;&amp;#039; numere naturale distincte care reprezintă anumite poziţii din şirul ordonat crescător al numerelor de pe cartonaşe. Însumând numerele aflate pe poziţiile din listă se determină un număr natural care reprezintă cifrul seifului. Cum Agentul 007 nu a mai programat din liceu, vă roagă pe voi să găsiţi cifrul în schimbul a 100 de … puncte.&lt;br /&gt;
== Date de intrare ==&lt;br /&gt;
Fișierul de intrare &amp;#039;&amp;#039;&amp;#039;memory007in.txt&amp;#039;&amp;#039;&amp;#039; conține pe prima linie numerele &amp;#039;&amp;#039;&amp;#039;n,m,a,b&amp;#039;&amp;#039;&amp;#039;, pe a doua linie &amp;#039;&amp;#039;&amp;#039;n&amp;#039;&amp;#039;&amp;#039; numere naturale distincte separate prin spații reprezentând numerele de pe cartonaşe, iar pe a treia linie &amp;#039;&amp;#039;&amp;#039;m&amp;#039;&amp;#039;&amp;#039; numere naturale distincte reprezentând poziţiile din listă.&lt;br /&gt;
== Date de ieşire ==&lt;br /&gt;
Fișierul de ieșire &amp;#039;&amp;#039;&amp;#039;memory007out.txt&amp;#039;&amp;#039;&amp;#039; va conține pe prima linie cifrul seifului.&lt;br /&gt;
== Restricții și precizări ==&lt;br /&gt;
* &amp;#039;&amp;#039;&amp;#039;1 &amp;amp;les; m &amp;amp;les; n &amp;amp;les; 500.000&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
* numerele de pe cartonaşe vor fi distincte şi mai mici decât &amp;#039;&amp;#039;&amp;#039;1.000.000.000&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
* numerele din listă vor fi naturale nenule, distincte şi mai mici sau egale cu &amp;#039;&amp;#039;&amp;#039;n&amp;#039;&amp;#039;&amp;#039;, ordonate crescător&lt;br /&gt;
* &amp;#039;&amp;#039;&amp;#039;1 &amp;amp;les; a &amp;amp;les; b &amp;amp;les; 1.000.000.000&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
* &amp;#039;&amp;#039;&amp;#039;n &amp;amp;les; b - a &amp;amp;les; 700.000&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
== Exemplul 1 ==&lt;br /&gt;
; memory007in.txt&lt;br /&gt;
 5 3 30 80&lt;br /&gt;
 78 56 34 45 61&lt;br /&gt;
 1 2 5&lt;br /&gt;
; memory007out.txt&lt;br /&gt;
 Datele de intrare corespund restrictiilor impuse.&lt;br /&gt;
 157&lt;br /&gt;
&amp;lt;br&amp;gt;&lt;br /&gt;
== Explicație ==&lt;br /&gt;
Numerele de pe cartonaşe sunt &amp;#039;&amp;#039;&amp;#039;78,56,34,45,61&amp;#039;&amp;#039;&amp;#039; şi sunt din intervalul [ &amp;#039;&amp;#039;&amp;#039;30,80&amp;#039;&amp;#039;&amp;#039; ]. Ordonate crescător formează şirul &amp;#039;&amp;#039;&amp;#039;34,45,56,61,78&amp;#039;&amp;#039;&amp;#039;. Numerele din listă, adică &amp;#039;&amp;#039;&amp;#039;1,2,5&amp;#039;&amp;#039;&amp;#039;, ne spun că cifrul se obţine însumând numerele de pe poziţiile &amp;#039;&amp;#039;&amp;#039;1&amp;#039;&amp;#039;&amp;#039;, &amp;#039;&amp;#039;&amp;#039;2&amp;#039;&amp;#039;&amp;#039; şi &amp;#039;&amp;#039;&amp;#039;5&amp;#039;&amp;#039;&amp;#039; din şirul ordonat crescător al numerelor de pe cartonaşe, adică cifrul este &amp;#039;&amp;#039;&amp;#039;34+45+78=157&amp;#039;&amp;#039;&amp;#039;.&lt;br /&gt;
&amp;lt;br&amp;gt;&lt;br /&gt;
== Exemplul 2 ==&lt;br /&gt;
; memory007in.txt&lt;br /&gt;
 rhgurhkfgrjg&lt;br /&gt;
; memory007out.txt&lt;br /&gt;
 Datele de intrare nu corespund restrictiilor impuse.&lt;br /&gt;
&amp;lt;br&amp;gt;&lt;br /&gt;
== Rezolvare ==&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;python&amp;quot; line&amp;gt;&lt;br /&gt;
# Funcția de validare verifică dacă datele de intrare sunt în intervalul specificat&lt;br /&gt;
def validare(n_validare, m_validare, a_validare, b_validare, cartonase_validare, pozitii_validare):&lt;br /&gt;
    # Verificăm dacă n este în intervalul 1-500000&lt;br /&gt;
    if n_validare &amp;lt; 1 or n_validare &amp;gt; 500000:&lt;br /&gt;
        raise ValueError&lt;br /&gt;
    # Verificăm dacă m este în intervalul 1-n&lt;br /&gt;
    if m_validare &amp;lt; 1 or m_validare &amp;gt; n_validare:&lt;br /&gt;
        raise ValueError&lt;br /&gt;
    # Verificăm dacă a este în intervalul 1-1000000000&lt;br /&gt;
    if a_validare &amp;lt; 1 or a_validare &amp;gt; 1000000000:&lt;br /&gt;
        raise ValueError&lt;br /&gt;
    # Verificăm dacă b este în intervalul a-1000000000&lt;br /&gt;
    if b_validare &amp;lt; a_validare or b_validare &amp;gt; 1000000000:&lt;br /&gt;
        raise ValueError&lt;br /&gt;
    if n_validare &amp;gt; b_validare - a_validare or b_validare - a_validare &amp;gt; 700000:&lt;br /&gt;
        raise ValueError  # Ridicăm o eroare dacă aceste condiții nu sunt îndeplinite&lt;br /&gt;
    # Parcurgem lista de valori de pe cartonașe&lt;br /&gt;
    for valoare in cartonase_validare:&lt;br /&gt;
        # Verificăm dacă valoarea este în intervalul a-b&lt;br /&gt;
        if valoare &amp;lt; a_validare or valoare &amp;gt; b_validare:&lt;br /&gt;
            raise ValueError&lt;br /&gt;
    for pozitie in pozitii_validare:    # Parcurgem lista de poziții&lt;br /&gt;
        # Verificăm dacă poziția este în intervalul 1-n&lt;br /&gt;
        if pozitie &amp;lt; 1 or pozitie &amp;gt; n_validare:&lt;br /&gt;
            raise ValueError&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;
# Funcția cifru_seif calculează cifrul seifului&lt;br /&gt;
def cifru_seif(cartonase, pozitii):&lt;br /&gt;
    cartonase.sort()&lt;br /&gt;
    cifru_calcul = sum(cartonase[pozitie - 1] for pozitie in pozitii)&lt;br /&gt;
    return cifru_calcul&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
if __name__ == &amp;#039;__main__&amp;#039;:&lt;br /&gt;
    file_in = open(&amp;quot;memory007in.txt&amp;quot;, &amp;quot;r&amp;quot;)&lt;br /&gt;
    file_out = open(&amp;quot;memory007out.txt&amp;quot;, &amp;quot;w&amp;quot;)&lt;br /&gt;
&lt;br /&gt;
    try:&lt;br /&gt;
        # Citim numărul de cartonașe, numărul de poziții, limita inferioară și limita superioară a intervalului&lt;br /&gt;
        n_main, m_main, a_main, b_main = map(int, file_in.readline().split())&lt;br /&gt;
        # Citim valorile de pe cartonașe&lt;br /&gt;
        cartonase_main = list(map(int, file_in.readline().split()))&lt;br /&gt;
        # Citim pozițiile&lt;br /&gt;
        pozitii_main = list(map(int, file_in.readline().split()))&lt;br /&gt;
        # Validăm datele de intrare&lt;br /&gt;
        validare(n_main, m_main, a_main, b_main, cartonase_main, pozitii_main)&lt;br /&gt;
        # Calculăm cifrul seifului&lt;br /&gt;
        cifru = cifru_seif(cartonase_main, pozitii_main)&lt;br /&gt;
        # Scriem cifrul în fișierul de ieșire&lt;br /&gt;
        file_out.write(str(cifru) + &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;
    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>AntalKrisztian</name></author>
	</entry>
</feed>