<?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=3577_-_Origami_1</id>
	<title>3577 - Origami 1 - Revision history</title>
	<link rel="self" type="application/atom+xml" href="https://wiki.universitas.ro/index.php?action=history&amp;feed=atom&amp;title=3577_-_Origami_1"/>
	<link rel="alternate" type="text/html" href="https://wiki.universitas.ro/index.php?title=3577_-_Origami_1&amp;action=history"/>
	<updated>2026-05-01T04:39:29Z</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=3577_-_Origami_1&amp;diff=10032&amp;oldid=prev</id>
		<title>AjM: Pagină nouă: == Enunt == Costel este pasionat de arta orientală a confecţionării obiectelor de hârtie, origami, dar este abia la început şi trebuie să se familiarizeze cu operaţiile de îndoire corectă a hârtiei. El are la dispoziţie o foaie de hârtie pătrată, ruptă dintr-un caiet de matematică, având dimensiunea de exact N x N pătrăţele. Îndoiturile trebuie realizate exact pe o linie orizontală sau verticală. Sunt permise două tipuri de îndoituri:  îndoitura de...</title>
		<link rel="alternate" type="text/html" href="https://wiki.universitas.ro/index.php?title=3577_-_Origami_1&amp;diff=10032&amp;oldid=prev"/>
		<updated>2024-06-03T17:14:03Z</updated>

		<summary type="html">&lt;p&gt;Pagină nouă: == Enunt == Costel este pasionat de arta orientală a confecţionării obiectelor de hârtie, origami, dar este abia la început şi trebuie să se familiarizeze cu operaţiile de îndoire corectă a hârtiei. El are la dispoziţie o foaie de hârtie pătrată, ruptă dintr-un caiet de matematică, având dimensiunea de exact N x N pătrăţele. Îndoiturile trebuie realizate exact pe o linie orizontală sau verticală. Sunt permise două tipuri de îndoituri:  îndoitura de...&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;== Enunt ==&lt;br /&gt;
Costel este pasionat de arta orientală a confecţionării obiectelor de hârtie, origami, dar este abia la început şi trebuie să se familiarizeze cu operaţiile de îndoire corectă a hârtiei. El are la dispoziţie o foaie de hârtie pătrată, ruptă dintr-un caiet de matematică, având dimensiunea de exact N x N pătrăţele. Îndoiturile trebuie realizate exact pe o linie orizontală sau verticală.&lt;br /&gt;
Sunt permise două tipuri de îndoituri:&lt;br /&gt;
&lt;br /&gt;
îndoitura de tipul 1, îndoitură verticală executată la X pătrăţele faţă de marginea stângă a foii: partea din stânga a foii se pliază către dreapta, de-a lungul liniei verticale aflate la distanţa de X pătrăţele faţă de marginea stângă;&lt;br /&gt;
îndoitura de tipul 2, îndoitură orizontală executată la X pătrăţele faţă de marginea superioară a foii: partea de sus a foii se pliază în jos, de-a lungul liniei aflate la distanţa de X pătrăţele faţă de marginea de sus a hârtiei.&lt;br /&gt;
&lt;br /&gt;
În urma realizării unei succesiuni de îndoituri, din foaia iniţială de hârtie se va obţine un obiect, care va avea o formă dreptunghiulară, cu înălţimea H, lăţimea M şi având grosimea egală cu numărul maxim de foi care se suprapun în cadrul obiectului obţinut.&lt;br /&gt;
== Cerinţa ==&lt;br /&gt;
Dată fiind o succesiune de îndoituri aplicată unei foi de dimensiune N x N, scrieţi un program care să determine înălţimea, lăţimea şi grosimea obiectului obţinut.&lt;br /&gt;
== Date de intrare ==&lt;br /&gt;
Fişierul de intrare origami1.in are următoarea structură :&lt;br /&gt;
&lt;br /&gt;
* prima linie a fişierului conţine un număr natural N, reprezentând dimensiunea iniţială a hârtiei;&lt;br /&gt;
a doua linie conţine un număr natural K, reprezentând numărul îndoiturilor;&lt;br /&gt;
* pe următoarele K linii se găsesc perechi de numere naturale nenule, A B, separate printr-un spaţiu, reprezentând tipul îndoiturii ( A este 1 dacă se realizează o îndoitură verticală sau A este 2 dacă se realizează o îndoitură orizontală), respectiv la ce distanţă se realizează îndoitura;&lt;br /&gt;
== Date de ieșire ==&lt;br /&gt;
Fişierul de ieşire origami1.out va conţine, pe o singură linie, trei numere naturale nenule H, L, G, separate prin câte un spaţiu, reprezentând înălţimea, lăţimea şi respectiv grosimea obiectului obţinut.&lt;br /&gt;
== Restricţii şi precizări ==&lt;br /&gt;
* 2 ≤ N ≤ 170&lt;br /&gt;
* 1 ≤ K ≤ 2N-2&lt;br /&gt;
* A = 1 sau A = 2&lt;br /&gt;
* 1 ≤ B &amp;lt; înălţimea sau lăţimea hârtiei la momentul respectiv (funcţie de tipul îndoiturii)&lt;br /&gt;
== Exemplu ==&lt;br /&gt;
; origami1.in&lt;br /&gt;
 4&lt;br /&gt;
 3&lt;br /&gt;
 1 3&lt;br /&gt;
 2 3&lt;br /&gt;
 1 1&lt;br /&gt;
; origami1.out&lt;br /&gt;
 3 2 6&lt;br /&gt;
&amp;lt;br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
== Explicație ==&lt;br /&gt;
Hârtia are 4 unităţi înălţime şi 4 unităţi lăţime. Prima îndoitură se realizează de la stânga la dreapta, de-a lungul celei de-a treia linii verticale faţă de marginea stângă a foii. Se obţine o foaie de înălţime 4, lăţime 3 şi grosime 2. A doua îndoitură se realizează îndoind partea superioară a foii, în jos, de-a lungul celei de-a treia linii orizontale faţă se marginea de sus a foii. Se obţine un obiect de înălţime 3, lăţime 3 şi grosime 4. După a treia îndoitură se obţine obiectul final, având înălţimea 3, lăţimea 2 şi grosimea 6.&lt;br /&gt;
== Rezolvare ==&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;python&amp;quot; line&amp;gt;&lt;br /&gt;
def fold_paper(N, K, folds):&lt;br /&gt;
    height = N&lt;br /&gt;
    width = N&lt;br /&gt;
    thickness = 1&lt;br /&gt;
&lt;br /&gt;
    for fold_type, position in folds:&lt;br /&gt;
        if fold_type == 1:&lt;br /&gt;
            # Îndoitură verticală&lt;br /&gt;
            width = min(position, N - position)&lt;br /&gt;
            thickness *= 2&lt;br /&gt;
        elif fold_type == 2:&lt;br /&gt;
            # Îndoitură orizontală&lt;br /&gt;
            height = min(position, N - position)&lt;br /&gt;
            thickness *= 2&lt;br /&gt;
&lt;br /&gt;
    return height, width, thickness&lt;br /&gt;
&lt;br /&gt;
def main():&lt;br /&gt;
    with open(&amp;quot;origami1.in&amp;quot;, &amp;quot;r&amp;quot;) as fin:&lt;br /&gt;
        N = int(fin.readline())&lt;br /&gt;
        K = int(fin.readline())&lt;br /&gt;
        folds = [list(map(int, fin.readline().split())) for _ in range(K)]&lt;br /&gt;
&lt;br /&gt;
    height, width, thickness = fold_paper(N, K, folds)&lt;br /&gt;
&lt;br /&gt;
    with open(&amp;quot;origami1.out&amp;quot;, &amp;quot;w&amp;quot;) as fout:&lt;br /&gt;
        fout.write(f&amp;quot;{height} {width} {thickness}\n&amp;quot;)&lt;br /&gt;
&lt;br /&gt;
if __name__ == &amp;quot;__main__&amp;quot;:&lt;br /&gt;
    main()&lt;br /&gt;
&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;/div&gt;</summary>
		<author><name>AjM</name></author>
	</entry>
</feed>