<?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=2170_-_Dreptc</id>
	<title>2170 - Dreptc - Revision history</title>
	<link rel="self" type="application/atom+xml" href="https://wiki.universitas.ro/index.php?action=history&amp;feed=atom&amp;title=2170_-_Dreptc"/>
	<link rel="alternate" type="text/html" href="https://wiki.universitas.ro/index.php?title=2170_-_Dreptc&amp;action=history"/>
	<updated>2026-05-01T03:41:00Z</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=2170_-_Dreptc&amp;diff=10051&amp;oldid=prev</id>
		<title>AjM: Pagină nouă: == Enunt == Se consideră n puncte colorate dispuse în plan. Ele sunt identificate prin coordonatele lor întregi, pe axele OX și OY. Fiecare punct are asociat un număr natural între 1 și C reprezentând codul culorii lui. Un dreptunghi se numește corect dacă îndeplinește simultan următoare condiții: * toate cele patru vârfuri se regăsesc printre cele n puncte date; * are laturile paralele cu axele OX, OY; * are vârfurile colorate în aceeași culoare. == Cerin...</title>
		<link rel="alternate" type="text/html" href="https://wiki.universitas.ro/index.php?title=2170_-_Dreptc&amp;diff=10051&amp;oldid=prev"/>
		<updated>2024-06-03T17:39:19Z</updated>

		<summary type="html">&lt;p&gt;Pagină nouă: == Enunt == Se consideră n puncte colorate dispuse în plan. Ele sunt identificate prin coordonatele lor întregi, pe axele OX și OY. Fiecare punct are asociat un număr natural între 1 și C reprezentând codul culorii lui. Un dreptunghi se numește corect dacă îndeplinește simultan următoare condiții: * toate cele patru vârfuri se regăsesc printre cele n puncte date; * are laturile paralele cu axele OX, OY; * are vârfurile colorate în aceeași culoare. == Cerin...&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;== Enunt ==&lt;br /&gt;
Se consideră n puncte colorate dispuse în plan. Ele sunt identificate prin coordonatele lor întregi, pe axele OX și OY. Fiecare punct are asociat un număr natural între 1 și C reprezentând codul culorii lui. Un dreptunghi se numește corect dacă îndeplinește simultan următoare condiții:&lt;br /&gt;
* toate cele patru vârfuri se regăsesc printre cele n puncte date;&lt;br /&gt;
* are laturile paralele cu axele OX, OY;&lt;br /&gt;
* are vârfurile colorate în aceeași culoare.&lt;br /&gt;
== Cerinţa ==&lt;br /&gt;
Să se determine numărul maxim de dreptunghiuri corecte care se pot forma cu cele n puncte din plan.&lt;br /&gt;
== Date de intrare ==&lt;br /&gt;
Pe prima linie a fișierului text dreptc.in se găsesc două numere n maxc reprezentând numărul de puncte din plan și numărul de culori asociate punctelor. Pe următoarele n linii se citesc câte trei numere x y c reprezentând în ordine coordonata pe axa OX (abscisa), coordonata pe axa OY (ordonata) și codul culorii asociate punctului. Nu există două puncte cu aceleași coordonate.&lt;br /&gt;
== Date de ieșire ==&lt;br /&gt;
Fișierul de ieșire dreptc.out va conține un singur număr reprezentând numărul maxim de dreptunghiuri corecte.&lt;br /&gt;
== Restricţii şi precizări ==&lt;br /&gt;
* 1 ≤ N ≤ 1000&lt;br /&gt;
* 1 ≤ C ≤ 5&lt;br /&gt;
* -1000 ≤ x , y ≤ 1000&lt;br /&gt;
* 40% din teste vor avea N ≤ 100&lt;br /&gt;
== Exemplu ==&lt;br /&gt;
; dreptc.in&lt;br /&gt;
 9 2&lt;br /&gt;
 3 10 1&lt;br /&gt;
 3 8 2&lt;br /&gt;
 3 6 1&lt;br /&gt;
 3 4 1&lt;br /&gt;
 3 0 1&lt;br /&gt;
 6 0 1&lt;br /&gt;
 6 4 1&lt;br /&gt;
 6 8 2&lt;br /&gt;
 6 10 1&lt;br /&gt;
; dreptc.out&lt;br /&gt;
 3&lt;br /&gt;
&amp;lt;br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
== Explicație ==&lt;br /&gt;
Vârfurile celor trei dreptunghiuri corecte sunt:&lt;br /&gt;
(3,0) (3,4) (6,4) (6,0)&lt;br /&gt;
(3,0) (3,10) (6,10) (6,0)&lt;br /&gt;
(3,6) (3,10) (6,10) (6,4).&lt;br /&gt;
== Rezolvare ==&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;python&amp;quot; line&amp;gt;&lt;br /&gt;
def count_rectangles(points):&lt;br /&gt;
    n = len(points)&lt;br /&gt;
    rectangles = 0&lt;br /&gt;
&lt;br /&gt;
    # Generate all possible rectangles&lt;br /&gt;
    for i in range(n):&lt;br /&gt;
        for j in range(i + 1, n):&lt;br /&gt;
            # Check if the other two points of the potential rectangle exist and have the same color&lt;br /&gt;
            x1, y1, c1 = points[i]&lt;br /&gt;
            x2, y2, c2 = points[j]&lt;br /&gt;
            if (x1, y2, c1) in points and (x2, y1, c1) in points and c1 == c2:&lt;br /&gt;
                rectangles += 1&lt;br /&gt;
&lt;br /&gt;
    return rectangles // 2  # Each rectangle is counted twice, so we divide by 2&lt;br /&gt;
&lt;br /&gt;
def main():&lt;br /&gt;
    # Read input&lt;br /&gt;
    with open(&amp;quot;dreptc.in&amp;quot;, &amp;quot;r&amp;quot;) as fin:&lt;br /&gt;
        n, maxc = map(int, fin.readline().split())&lt;br /&gt;
        points = [tuple(map(int, fin.readline().split())) for _ in range(n)]&lt;br /&gt;
&lt;br /&gt;
    # Count rectangles&lt;br /&gt;
    result = count_rectangles(points)&lt;br /&gt;
&lt;br /&gt;
    # Write output&lt;br /&gt;
    with open(&amp;quot;dreptc.out&amp;quot;, &amp;quot;w&amp;quot;) as fout:&lt;br /&gt;
        fout.write(str(result) + &amp;quot;\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>