<?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=0932_-_Aria_Poligon_Simplu</id>
	<title>0932 - Aria Poligon Simplu - Revision history</title>
	<link rel="self" type="application/atom+xml" href="https://wiki.universitas.ro/index.php?action=history&amp;feed=atom&amp;title=0932_-_Aria_Poligon_Simplu"/>
	<link rel="alternate" type="text/html" href="https://wiki.universitas.ro/index.php?title=0932_-_Aria_Poligon_Simplu&amp;action=history"/>
	<updated>2026-05-01T06:37:57Z</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=0932_-_Aria_Poligon_Simplu&amp;diff=8956&amp;oldid=prev</id>
		<title>Codrut Borcutean: Pagină nouă: == Cerinţa == Se dau coordonatele în plan pentru &#039;&#039;&#039;n&#039;&#039;&#039; puncte. Să se afișeze valoarea ariei poligonului pe care acestea îl formează. == Date de intrare == Fișierul de intrare &#039;&#039;&#039;ariapoligonsimpluin.txt&#039;&#039;&#039; conține pe prima linie numărul de vârfuri ale poligonului, notat cu &#039;&#039;&#039;n&#039;&#039;&#039;. Pe următoarele &#039;&#039;&#039;n&#039;&#039;&#039; linii se găsesc câte două numere separate printr-un spațiu, reprezentând abscisa respectiv ordonata câte unui vârf. Acestea sunt date într-un sens de parc...</title>
		<link rel="alternate" type="text/html" href="https://wiki.universitas.ro/index.php?title=0932_-_Aria_Poligon_Simplu&amp;diff=8956&amp;oldid=prev"/>
		<updated>2024-01-04T09:50:39Z</updated>

		<summary type="html">&lt;p&gt;Pagină nouă: == Cerinţa == Se dau coordonatele în plan pentru &amp;#039;&amp;#039;&amp;#039;n&amp;#039;&amp;#039;&amp;#039; puncte. Să se afișeze valoarea ariei poligonului pe care acestea îl formează. == Date de intrare == Fișierul de intrare &amp;#039;&amp;#039;&amp;#039;ariapoligonsimpluin.txt&amp;#039;&amp;#039;&amp;#039; conține pe prima linie numărul de vârfuri ale poligonului, notat cu &amp;#039;&amp;#039;&amp;#039;n&amp;#039;&amp;#039;&amp;#039;. Pe următoarele &amp;#039;&amp;#039;&amp;#039;n&amp;#039;&amp;#039;&amp;#039; linii se găsesc câte două numere separate printr-un spațiu, reprezentând abscisa respectiv ordonata câte unui vârf. Acestea sunt date într-un sens de parc...&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;
Se dau coordonatele în plan pentru &amp;#039;&amp;#039;&amp;#039;n&amp;#039;&amp;#039;&amp;#039; puncte. Să se afișeze valoarea ariei poligonului pe care acestea îl formează.&lt;br /&gt;
== Date de intrare ==&lt;br /&gt;
Fișierul de intrare &amp;#039;&amp;#039;&amp;#039;ariapoligonsimpluin.txt&amp;#039;&amp;#039;&amp;#039; conține pe prima linie numărul de vârfuri ale poligonului, notat cu &amp;#039;&amp;#039;&amp;#039;n&amp;#039;&amp;#039;&amp;#039;. Pe următoarele &amp;#039;&amp;#039;&amp;#039;n&amp;#039;&amp;#039;&amp;#039; linii se găsesc câte două numere separate printr-un spațiu, reprezentând abscisa respectiv ordonata câte unui vârf. Acestea sunt date într-un sens de parcurgere a laturilor poligonului.&lt;br /&gt;
== Date de ieșire ==&lt;br /&gt;
Fișierul de ieșire &amp;#039;&amp;#039;&amp;#039;ariapoligonsimpluout.txt&amp;#039;&amp;#039;&amp;#039; va conține pe prima linie un număr real, cu exact o zecimală, reprezentând valoarea cerută.&lt;br /&gt;
== Restricţii şi precizări ==&lt;br /&gt;
* Numerele din fișierul de intrare sunt întregi cuprinse între &amp;#039;&amp;#039;&amp;#039;-1001&amp;#039;&amp;#039;&amp;#039; și &amp;#039;&amp;#039;&amp;#039;1001&amp;#039;&amp;#039;&amp;#039;.&lt;br /&gt;
* Poligonul nu este neapărat convex dar nu se autointersectează.&lt;br /&gt;
== Exemplu 1 ==&lt;br /&gt;
; ariapoligonsimpluin.txt&lt;br /&gt;
 4&lt;br /&gt;
 0 0&lt;br /&gt;
 1 0&lt;br /&gt;
 1 1&lt;br /&gt;
 0 1&lt;br /&gt;
; ariapoligonsimpluout.txt&lt;br /&gt;
 Datele de intrare corespund restrictiilor impuse&lt;br /&gt;
 1.0&lt;br /&gt;
&amp;lt;br&amp;gt;&lt;br /&gt;
== Exemplu 2 ==&lt;br /&gt;
; ariapoligonsimpluin.txt&lt;br /&gt;
 4&lt;br /&gt;
 0 0&lt;br /&gt;
 1 0&lt;br /&gt;
 1 5000&lt;br /&gt;
 0 1&lt;br /&gt;
; ariapoligonsimpluout.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;
def calculeaza_arie(puncte):&lt;br /&gt;
    # Calculează aria unui poligon dat prin coordonatele punctelor sale.&lt;br /&gt;
&lt;br /&gt;
    n = len(puncte)&lt;br /&gt;
    arie = 0.0&lt;br /&gt;
    for i in range(n):&lt;br /&gt;
        j = (i + 1) % n&lt;br /&gt;
        arie += puncte[i][0] * puncte[j][1]&lt;br /&gt;
        arie -= puncte[j][0] * puncte[i][1]&lt;br /&gt;
    arie = abs(arie) / 2.0&lt;br /&gt;
    return arie&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
def main():&lt;br /&gt;
    with open(&amp;#039;ariapoligonsimpluin.txt&amp;#039;, &amp;#039;r&amp;#039;) as fin, open(&amp;#039;ariapoligonsimpluout.txt&amp;#039;, &amp;#039;w&amp;#039;) as fout:&lt;br /&gt;
        n = int(fin.readline().strip())&lt;br /&gt;
        puncte = []&lt;br /&gt;
        for _ in range(n):&lt;br /&gt;
            x, y = map(int, fin.readline().split())&lt;br /&gt;
            puncte.append((x, y))&lt;br /&gt;
&lt;br /&gt;
        # Verifică dacă datele de intrare respectă restricțiile&lt;br /&gt;
        if not all(-1001 &amp;lt;= x &amp;lt;= 1001 and -1001 &amp;lt;= y &amp;lt;= 1001 for x, y in puncte):&lt;br /&gt;
            fout.write(&amp;quot;Datele de intrare nu corespund restrictiilor impuse\n&amp;quot;)&lt;br /&gt;
            return&lt;br /&gt;
&lt;br /&gt;
        fout.write(&amp;quot;Datele de intrare corespund restrictiilor impuse\n&amp;quot;)&lt;br /&gt;
&lt;br /&gt;
        arie = calculeaza_arie(puncte)&lt;br /&gt;
        fout.write(f&amp;quot;{arie:.1f}\n&amp;quot;)&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
if __name__ == &amp;quot;__main__&amp;quot;:&lt;br /&gt;
    main()&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;/div&gt;</summary>
		<author><name>Codrut Borcutean</name></author>
	</entry>
</feed>