<?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=1963_-_OP</id>
	<title>1963 - OP - Revision history</title>
	<link rel="self" type="application/atom+xml" href="https://wiki.universitas.ro/index.php?action=history&amp;feed=atom&amp;title=1963_-_OP"/>
	<link rel="alternate" type="text/html" href="https://wiki.universitas.ro/index.php?title=1963_-_OP&amp;action=history"/>
	<updated>2026-05-01T08:28:54Z</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=1963_-_OP&amp;diff=8203&amp;oldid=prev</id>
		<title>Vasiliu Costel Andrei: Pagină nouă: == Enunț == Șcuțu este un mare matematician. Într-o seară acesta a inventat operația ∆. Operația ∆ se aplică pe 2 numere naturale, astfel:  290 ∆ 345 = 290345 &lt;br&gt; 21 ∆ 12 = 2112&lt;br&gt; 456 ∆ 0 = 4560  Mygo și Seba sunt la rândul lor foarte buni informaticieni. Aceștia au un vector A cu N elemente, numere naturale, indexate de la 1. Ei vor construi un nou vector V, acesta la rândul său indexat de la 1, ce conține fiecare valoare A[i] ∆ A[j] (1 ≤ i, j...</title>
		<link rel="alternate" type="text/html" href="https://wiki.universitas.ro/index.php?title=1963_-_OP&amp;diff=8203&amp;oldid=prev"/>
		<updated>2023-12-17T09:22:41Z</updated>

		<summary type="html">&lt;p&gt;Pagină nouă: == Enunț == Șcuțu este un mare matematician. Într-o seară acesta a inventat operația ∆. Operația ∆ se aplică pe 2 numere naturale, astfel:  290 ∆ 345 = 290345 &amp;lt;br&amp;gt; 21 ∆ 12 = 2112&amp;lt;br&amp;gt; 456 ∆ 0 = 4560  Mygo și Seba sunt la rândul lor foarte buni informaticieni. Aceștia au un vector A cu N elemente, numere naturale, indexate de la 1. Ei vor construi un nou vector V, acesta la rândul său indexat de la 1, ce conține fiecare valoare A[i] ∆ A[j] (1 ≤ i, j...&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;== Enunț ==&lt;br /&gt;
Șcuțu este un mare matematician. Într-o seară acesta a inventat operația ∆. Operația ∆ se aplică pe 2 numere naturale, astfel:&lt;br /&gt;
&lt;br /&gt;
290 ∆ 345 = 290345 &amp;lt;br&amp;gt;&lt;br /&gt;
21 ∆ 12 = 2112&amp;lt;br&amp;gt;&lt;br /&gt;
456 ∆ 0 = 4560&lt;br /&gt;
&lt;br /&gt;
Mygo și Seba sunt la rândul lor foarte buni informaticieni. Aceștia au un vector A cu N elemente, numere naturale, indexate de la 1. Ei vor construi un nou vector V, acesta la rândul său indexat de la 1, ce conține fiecare valoare A[i] ∆ A[j] (1 ≤ i, j ≤ N) pe care îl vor sorta crescător.&lt;br /&gt;
&lt;br /&gt;
== Cerința ==&lt;br /&gt;
Acum Șcuțu le va pune celor 2 câte două întrebări:&lt;br /&gt;
&lt;br /&gt;
1. Câte valori din V sunt mai mici sau egale cu X ? &amp;lt;br&amp;gt;&lt;br /&gt;
2. Pentru X dat, ce valoare se află pe poziția X ?&lt;br /&gt;
&lt;br /&gt;
Să se răspundă la cele 2 întrebări.&lt;br /&gt;
&lt;br /&gt;
== Date de intrare ==&lt;br /&gt;
Fișierul de intrare opin.txt conține pe prima linie numărul t, având valoarea 1 sau 2, reprezentând tipul întrebării la care se cere răspunsul. Pe a doua linie linie se află numărul N și X iar pe a treia linie se vor afla N numere naturale nenule, reprezentând valorile vectorului A.&lt;br /&gt;
&lt;br /&gt;
== Date de ieșire ==&lt;br /&gt;
Fișierul de ieșire opout.txt va conține pe prima linie numărul S, reprezentând răspunsul întrebării.&lt;br /&gt;
&lt;br /&gt;
== Restricții și precizări ==&lt;br /&gt;
* 1 &amp;amp;les; &amp;#039;&amp;#039;&amp;#039;N&amp;#039;&amp;#039;&amp;#039; &amp;amp;les; 100.000&lt;br /&gt;
* numerele de pe a treia linie a fișierului de intrare vor fi mai mici decât 1.000.000.000&lt;br /&gt;
&lt;br /&gt;
== Exemplul 1 ==&lt;br /&gt;
; Intrare&lt;br /&gt;
; opin.txt&lt;br /&gt;
: 1&lt;br /&gt;
: 3 23&lt;br /&gt;
: 1 2 4&lt;br /&gt;
; Ieșire&lt;br /&gt;
: Datele de intrare corespund restricțiilor impuse&lt;br /&gt;
; opout.txt&lt;br /&gt;
: 5&lt;br /&gt;
&lt;br /&gt;
=== Explicație ===&lt;br /&gt;
V = {11, 12, 14, 21, 22, 24, 41, 42, 44}. Sunt 5 numere mai mici decât 23.&lt;br /&gt;
&lt;br /&gt;
== Exemplul 2 ==&lt;br /&gt;
; Intrare&lt;br /&gt;
; opin.txt&lt;br /&gt;
: 2&lt;br /&gt;
: 3 6&lt;br /&gt;
: 1 2 4&lt;br /&gt;
; Ieșire&lt;br /&gt;
: Datele de intrare corespund restricțiilor impuse&lt;br /&gt;
; opout.txt&lt;br /&gt;
: 24&lt;br /&gt;
&lt;br /&gt;
=== Explicație ===&lt;br /&gt;
V = {11, 12, 14, 21, 22, 24, 41, 42, 44}. Pe poziția 6 se află numărul 24.&lt;br /&gt;
&lt;br /&gt;
== Exemplul 3 ==&lt;br /&gt;
; Intrare&lt;br /&gt;
; opin.txt&lt;br /&gt;
: 3&lt;br /&gt;
: 3 6&lt;br /&gt;
: 1 2 4&lt;br /&gt;
; Ieșire&lt;br /&gt;
: Datele de intrare NU corespund restricțiilor impuse&lt;br /&gt;
&lt;br /&gt;
== Rezolvare ==&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;python&amp;quot; line&amp;gt;&lt;br /&gt;
#1963 - Op&lt;br /&gt;
&lt;br /&gt;
def valideaza_input(t, n, a):&lt;br /&gt;
    if t not in [1, 2]:&lt;br /&gt;
        return False&lt;br /&gt;
    if not 1 &amp;lt;= n &amp;lt;= 100000:&lt;br /&gt;
        return False&lt;br /&gt;
    if not all(0 &amp;lt; ai &amp;lt; 1000000000 for ai in a):&lt;br /&gt;
        return False&lt;br /&gt;
    return True&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
def calculeaza_v(n, a):&lt;br /&gt;
    v = []&lt;br /&gt;
    for i in range(n):&lt;br /&gt;
        for j in range(n):&lt;br /&gt;
            v.append(int(str(a[i]) + str(a[j])))&lt;br /&gt;
    return sorted(v)&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
def numara_valori_mai_mici_sau_egale_cu_x(v, x):&lt;br /&gt;
    count = 0&lt;br /&gt;
    for value in v:&lt;br /&gt;
        if value &amp;lt;= x:&lt;br /&gt;
            count += 1&lt;br /&gt;
    return count&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
def gaseste_valoare_pe_pozitia_x(v, x):&lt;br /&gt;
    return v[x - 1]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
if __name__ == &amp;quot;__main__&amp;quot;:&lt;br /&gt;
    rezultat = 0&lt;br /&gt;
    with open(&amp;quot;opin.txt&amp;quot;, &amp;quot;r&amp;quot;) as file:&lt;br /&gt;
        t = int(file.readline().strip())&lt;br /&gt;
        n, x = map(int, file.readline().strip().split())&lt;br /&gt;
        a = list(map(int, file.readline().strip().split()))&lt;br /&gt;
&lt;br /&gt;
    if valideaza_input(t, n, a):&lt;br /&gt;
        print(&amp;quot;Datele de intrare corespund restricțiilor impuse&amp;quot;)&lt;br /&gt;
        if t == 1:&lt;br /&gt;
            v = calculeaza_v(n, a)&lt;br /&gt;
            rezultat = numara_valori_mai_mici_sau_egale_cu_x(v, x)&lt;br /&gt;
        elif t == 2:&lt;br /&gt;
            v = calculeaza_v(n, a)&lt;br /&gt;
            rezultat = gaseste_valoare_pe_pozitia_x(v, x)&lt;br /&gt;
    else:&lt;br /&gt;
        print(&amp;quot;Datele de intrare NU corespund restricțiilor impuse&amp;quot;)&lt;br /&gt;
        exit(0)&lt;br /&gt;
&lt;br /&gt;
    with open(&amp;quot;opout.txt&amp;quot;, &amp;quot;w&amp;quot;) as output_file:&lt;br /&gt;
        output_file.write(str(rezultat))&lt;br /&gt;
&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;/div&gt;</summary>
		<author><name>Vasiliu Costel Andrei</name></author>
	</entry>
</feed>