<?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=1695_-_Oglinda</id>
	<title>1695 - Oglinda - Revision history</title>
	<link rel="self" type="application/atom+xml" href="https://wiki.universitas.ro/index.php?action=history&amp;feed=atom&amp;title=1695_-_Oglinda"/>
	<link rel="alternate" type="text/html" href="https://wiki.universitas.ro/index.php?title=1695_-_Oglinda&amp;action=history"/>
	<updated>2026-05-01T04:47:08Z</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=1695_-_Oglinda&amp;diff=8224&amp;oldid=prev</id>
		<title>Vasiliu Costel Andrei: Pagină nouă: == Enunț == Pentru un număr natural N se consideră șirul a=(1,2,3...,N), deci a[i]=i pentru orice i, 1≤i≤N.  Asupra acestui șir se pot aplica operații de două tipuri:  a) la operația de tipul 1 se specifică două valori i și j, cu 1≤i≤j≤N. Efectul acestei operații asupra șirului este de oglindire a secvenței din șir care începe cu elementul de pe poziția i și se termină cu cel de pe poziția j. De exemplu, dacă în șirul a=(1,2,3,4,5,6,7) se apli...</title>
		<link rel="alternate" type="text/html" href="https://wiki.universitas.ro/index.php?title=1695_-_Oglinda&amp;diff=8224&amp;oldid=prev"/>
		<updated>2023-12-17T16:45:58Z</updated>

		<summary type="html">&lt;p&gt;Pagină nouă: == Enunț == Pentru un număr natural N se consideră șirul a=(1,2,3...,N), deci a[i]=i pentru orice i, 1≤i≤N.  Asupra acestui șir se pot aplica operații de două tipuri:  a) la operația de tipul 1 se specifică două valori i și j, cu 1≤i≤j≤N. Efectul acestei operații asupra șirului este de oglindire a secvenței din șir care începe cu elementul de pe poziția i și se termină cu cel de pe poziția j. De exemplu, dacă în șirul a=(1,2,3,4,5,6,7) se apli...&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;== Enunț ==&lt;br /&gt;
Pentru un număr natural N se consideră șirul a=(1,2,3...,N), deci a[i]=i pentru orice i, 1≤i≤N.&lt;br /&gt;
&lt;br /&gt;
Asupra acestui șir se pot aplica operații de două tipuri:&lt;br /&gt;
&lt;br /&gt;
a) la operația de tipul 1 se specifică două valori i și j, cu 1≤i≤j≤N. Efectul acestei operații asupra șirului este de oglindire a secvenței din șir care începe cu elementul de pe poziția i și se termină cu cel de pe poziția j. De exemplu, dacă în șirul a=(1,2,3,4,5,6,7) se aplică operația 3 6, atunci șirul devine a=(1,2,6,5,4,3,7). Iar în șirul a=(1,4,3,2,5,6,7), dacă se aplică operația 4 6, atunci a=(1,4,3,6,5,2,7).&amp;lt;br&amp;gt;&lt;br /&gt;
b) Operația de tipul 2 conține un indice i, 1≤i≤N, și cere să afișăm valoarea elementului care se află în acel moment pe poziția i în șir.&lt;br /&gt;
&lt;br /&gt;
Se consideră M astfel de operații într-o ordine dată.&lt;br /&gt;
&lt;br /&gt;
== Cerința ==&lt;br /&gt;
Scrieți un program care să determine și să afișeze rezultatul pentru fiecare operație de tipul 2.&lt;br /&gt;
&lt;br /&gt;
== Date de intrare ==&lt;br /&gt;
Fișierul de intrare oglindain.txt conține pe prima linie două numere naturale N și M, separate printr-un spațiu. Pe fiecare dintre următoarele M linii este specificată câte o operație de tipul 1 sau 2. O linie poate să conțină două sau trei numere, astfel: 1 i j (indicând o operație de tipul 1) respectiv 2 i (indicând o operație de tip 2). Valorile de pe aceeași linie sunt separate prin câte un spațiu.&lt;br /&gt;
&lt;br /&gt;
== Date de ieșire ==&lt;br /&gt;
Fișierul de ieșire oglindaout.txt va conține un număr de linii egal cu numărul de operații de tipul 2 care sunt definite în fișierul de intrare. Pe fiecare linie este afișat câte un număr natural reprezintând rezultatul pentru o operație de tip 2 prezentă în fișierul de intrare, în ordinea în care acestea sunt definite.&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; 1.000.000&lt;br /&gt;
* 1 &amp;amp;les; &amp;#039;&amp;#039;&amp;#039;M&amp;#039;&amp;#039;&amp;#039; &amp;amp;les; 2.000&lt;br /&gt;
* Se garantează că 1 ≤ i ≤ j ≤ N la operațiile de tipul 1 și că 1 ≤ i ≤ N la operațiile de tip 2.&lt;br /&gt;
* Se garantează că există cel puțin o operație de tipul 2.&lt;br /&gt;
&lt;br /&gt;
== Exemplul 1 ==&lt;br /&gt;
; Intrare&lt;br /&gt;
; oglindain.txt&lt;br /&gt;
: 10 4&lt;br /&gt;
: 2 3&lt;br /&gt;
: 1 2 7&lt;br /&gt;
: 2 3&lt;br /&gt;
: 2 1&lt;br /&gt;
; Ieșire&lt;br /&gt;
: Datele de intrare corespund restricțiilor impuse&lt;br /&gt;
; oglindaout.txt&lt;br /&gt;
: 3&lt;br /&gt;
: 6&lt;br /&gt;
: 1&lt;br /&gt;
&lt;br /&gt;
=== Explicație ===&lt;br /&gt;
Șirul inițial este: 1 2 3 4 5 6 7 8 9 10 &amp;lt;br&amp;gt;&lt;br /&gt;
Rezultatul operației 2 3 are ca efect afișarea elementului de pe poziția 3 (care este chiar 3).&amp;lt;br&amp;gt;&lt;br /&gt;
Rezultatul operației 1 2 7 are ca efect transformarea șirului în: &amp;lt;br&amp;gt;&lt;br /&gt;
1 7 6 5 4 3 2 8 9 10.&amp;lt;br&amp;gt;&lt;br /&gt;
Rezultatul operației 2 3 are ca efect afișarea elementului de pe poziția 3 (care acum este 6).&amp;lt;br&amp;gt;&lt;br /&gt;
Rezultatul operației 2 1 are ca efect afișarea elementului de pe poziția 1 (care acum are valoarea 1).&amp;lt;br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
== Exemplul 2 ==&lt;br /&gt;
; Intrare&lt;br /&gt;
; oglindain.txt&lt;br /&gt;
: 10 2023&lt;br /&gt;
: 2 3&lt;br /&gt;
: 1 2 7&lt;br /&gt;
: 2 3&lt;br /&gt;
: 2 1&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;
#1695 - Oglinda&lt;br /&gt;
&lt;br /&gt;
def oglinda(n, operatii):&lt;br /&gt;
    sir = list(range(1, n + 1))&lt;br /&gt;
    rezultate = []&lt;br /&gt;
    for operatie in operatii:&lt;br /&gt;
        tip = operatie[0]&lt;br /&gt;
        if tip == 1:&lt;br /&gt;
            i, j = operatie[1], operatie[2]&lt;br /&gt;
            sir[i - 1:j] = reversed(sir[i - 1:j])&lt;br /&gt;
        elif tip == 2:&lt;br /&gt;
            i = operatie[1]&lt;br /&gt;
            rezultate.append(sir[i - 1])&lt;br /&gt;
    with open(&amp;quot;oglindaout.txt&amp;quot;, &amp;quot;w&amp;quot;) as output_file:&lt;br /&gt;
        for rezultat in rezultate:&lt;br /&gt;
            output_file.write(str(rezultat) + &amp;quot;\n&amp;quot;)&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
def validare_date(n, m, operatii):&lt;br /&gt;
    if not (1 &amp;lt;= n &amp;lt;= 1000000):&lt;br /&gt;
        return False&lt;br /&gt;
    if not (1 &amp;lt;= m &amp;lt;= 2000):&lt;br /&gt;
        return False&lt;br /&gt;
    for operatie in operatii:&lt;br /&gt;
        tip = operatie[0]&lt;br /&gt;
        if tip == 1:&lt;br /&gt;
            i, j = operatie[1], operatie[2]&lt;br /&gt;
            if not (1 &amp;lt;= i &amp;lt;= j &amp;lt;= n):&lt;br /&gt;
                return False&lt;br /&gt;
        elif tip == 2:&lt;br /&gt;
            i = operatie[1]&lt;br /&gt;
            if not (1 &amp;lt;= i &amp;lt;= n):&lt;br /&gt;
                return False&lt;br /&gt;
    return True&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
if __name__ == &amp;quot;__main__&amp;quot;:&lt;br /&gt;
    with open(&amp;quot;oglindain.txt&amp;quot;, &amp;quot;r&amp;quot;) as f:&lt;br /&gt;
        n, m = map(int, f.readline().split())&lt;br /&gt;
        operatii = [list(map(int, line.split())) for line in f]&lt;br /&gt;
    if validare_date(n, m, operatii):&lt;br /&gt;
        print(&amp;quot;Datele de intrare corespund restricțiilor impuse&amp;quot;)&lt;br /&gt;
        oglinda(n, operatii)&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;
&amp;lt;/syntaxhighlight&amp;gt;&lt;/div&gt;</summary>
		<author><name>Vasiliu Costel Andrei</name></author>
	</entry>
</feed>