<?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=4128_-_Iluminat</id>
	<title>4128 - Iluminat - Revision history</title>
	<link rel="self" type="application/atom+xml" href="https://wiki.universitas.ro/index.php?action=history&amp;feed=atom&amp;title=4128_-_Iluminat"/>
	<link rel="alternate" type="text/html" href="https://wiki.universitas.ro/index.php?title=4128_-_Iluminat&amp;action=history"/>
	<updated>2026-05-01T07:34:38Z</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=4128_-_Iluminat&amp;diff=10201&amp;oldid=prev</id>
		<title>RaulOtet: Pagină nouă: Primarul orașului X dorește să aibă un iluminat public modern. Pentru aceasta, realizează o schiță sub forma unui pătrat cu &lt;code&gt;n&lt;/code&gt; linii și &lt;code&gt;n&lt;/code&gt; coloane în care fiecare element situat la intersecția unei linii cu o coloană reprezintă un cartier.  Primarul a calculat pentru fiecare cartier care este numărul de stâlpi de iluminat public din acel cartier. Fiecare stâlp are un singur bec care inițial este aprins. Acesta a observat un lucru inter...</title>
		<link rel="alternate" type="text/html" href="https://wiki.universitas.ro/index.php?title=4128_-_Iluminat&amp;diff=10201&amp;oldid=prev"/>
		<updated>2024-07-31T05:46:06Z</updated>

		<summary type="html">&lt;p&gt;Pagină nouă: Primarul orașului X dorește să aibă un iluminat public modern. Pentru aceasta, realizează o schiță sub forma unui pătrat cu &amp;lt;code&amp;gt;n&amp;lt;/code&amp;gt; linii și &amp;lt;code&amp;gt;n&amp;lt;/code&amp;gt; coloane în care fiecare element situat la intersecția unei linii cu o coloană reprezintă un cartier.  Primarul a calculat pentru fiecare cartier care este numărul de stâlpi de iluminat public din acel cartier. Fiecare stâlp are un singur bec care inițial este aprins. Acesta a observat un lucru inter...&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;Primarul orașului X dorește să aibă un iluminat public modern. Pentru aceasta, realizează o schiță sub forma unui pătrat cu &amp;lt;code&amp;gt;n&amp;lt;/code&amp;gt; linii și &amp;lt;code&amp;gt;n&amp;lt;/code&amp;gt; coloane în care fiecare element situat la intersecția unei linii cu o coloană reprezintă un cartier.&lt;br /&gt;
&lt;br /&gt;
Primarul a calculat pentru fiecare cartier care este numărul de stâlpi de iluminat public din acel cartier. Fiecare stâlp are un singur bec care inițial este aprins. Acesta a observat un lucru interesant: toate cartierele au un număr diferit de stâlpi de iluminare, iar valoarea maximă a numărului de stâlpi dintr-un cartier este &amp;lt;code&amp;gt;n&amp;lt;sup&amp;gt;2&amp;lt;/sup&amp;gt;&amp;lt;/code&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
Pentru a fi realizată într-un mod cât mai eficient, stingerea becurilor se realizează în următorul mod:&lt;br /&gt;
&lt;br /&gt;
* în prima etapă se sting becurile din cartierul cu număr maxim de stâlpi de iluminat, ceea ce duce la stingerea becurilor din cartierele de pe aceeași linie precum și din cele pe aceeași coloană cu cartierul cu număr maxim de stâlpi.&lt;br /&gt;
* procedeul se reia la fiecare etapă pentru toate cartierele în care nu au fost stinse becurile, până când rămâne un singur cartier iluminat.&lt;br /&gt;
&lt;br /&gt;
= Cerința =&lt;br /&gt;
Cunoscând numerele naturale nenule &amp;lt;code&amp;gt;n&amp;lt;/code&amp;gt; și &amp;lt;code&amp;gt;k&amp;lt;/code&amp;gt;, precum și numărul de stâlpi de iluminat din fiecare cartier, să se determine:&lt;br /&gt;
&lt;br /&gt;
* Câți stâlpi de iluminat se află în cartierul cu număr maxim de stâlpi de iluminat la etapa cu numărul &amp;lt;code&amp;gt;k&amp;lt;/code&amp;gt; din procedeul de stingere a becurilor?&lt;br /&gt;
* Câte becuri se sting, în total, la etapa cu numărul &amp;lt;code&amp;gt;k&amp;lt;/code&amp;gt;?&lt;br /&gt;
* Care este numărul maxim de becuri aprinse într-o zonă pătratică a orașului de dimensiune &amp;lt;code&amp;gt;k x k&amp;lt;/code&amp;gt;, înainte de a începe stingerea becurilor?&lt;br /&gt;
&lt;br /&gt;
= Date de intrare =&lt;br /&gt;
Fișierul de intrare &amp;lt;code&amp;gt;iluminat.in&amp;lt;/code&amp;gt; conține pe prima linie o cifră &amp;lt;code&amp;gt;c&amp;lt;/code&amp;gt; (&amp;lt;code&amp;gt;1&amp;lt;/code&amp;gt;, &amp;lt;code&amp;gt;2&amp;lt;/code&amp;gt; sau &amp;lt;code&amp;gt;3&amp;lt;/code&amp;gt;), reprezentând cerința cerută. Pe linia următoare se găsesc două numere naturale nenule &amp;lt;code&amp;gt;n&amp;lt;/code&amp;gt; și &amp;lt;code&amp;gt;k&amp;lt;/code&amp;gt;, separate printr-un spațiu. Pe următoarele &amp;lt;code&amp;gt;n&amp;lt;/code&amp;gt; linii se află &amp;lt;code&amp;gt;n&amp;lt;sup&amp;gt;2&amp;lt;/sup&amp;gt;&amp;lt;/code&amp;gt; numere naturale distincte, câte &amp;lt;code&amp;gt;n&amp;lt;/code&amp;gt; pe fiecare linie, separate prin câte un spațiu, cu semnificația din enunț.&lt;br /&gt;
&lt;br /&gt;
= Date de ieșire =&lt;br /&gt;
În fișierul de ieșire &amp;lt;code&amp;gt;iluminat.out&amp;lt;/code&amp;gt; se va afișa răspunsul în funcție de cerință:&lt;br /&gt;
&lt;br /&gt;
* dacă &amp;lt;code&amp;gt;c = 1&amp;lt;/code&amp;gt; se va afișa pe prima linie un singur număr reprezentând numărul de stâlpi de iluminat din cartierul cu număr maxim de stâlpi de iluminat la etapa &amp;lt;code&amp;gt;k&amp;lt;/code&amp;gt;&lt;br /&gt;
* dacă &amp;lt;code&amp;gt;c = 2&amp;lt;/code&amp;gt; se va afișa pe prima linie un singur număr reprezentând câte becuri se sting, în total, la etapa cu numărul &amp;lt;code&amp;gt;k&amp;lt;/code&amp;gt;&lt;br /&gt;
* dacă &amp;lt;code&amp;gt;c = 3&amp;lt;/code&amp;gt; se va afișa numărul maxim de becuri aprinse într-o zonă pătratică de dimensiune &amp;lt;code&amp;gt;k x k&amp;lt;/code&amp;gt; înainte de stingerea becurilor&lt;br /&gt;
&lt;br /&gt;
= Restricții și precizări =&lt;br /&gt;
&lt;br /&gt;
* &amp;lt;code&amp;gt;c ∈ {1, 2, 3}&amp;lt;/code&amp;gt;&lt;br /&gt;
* &amp;lt;code&amp;gt;1 ≤ k &amp;lt; n ≤ 1000&amp;lt;/code&amp;gt;&lt;br /&gt;
* Numărul de becuri din fiecare cartier este mai mic sau egal cu &amp;lt;code&amp;gt;n&amp;lt;sup&amp;gt;2&amp;lt;/sup&amp;gt;&amp;lt;/code&amp;gt;&lt;br /&gt;
&lt;br /&gt;
= Exemplu: =&lt;br /&gt;
&amp;lt;code&amp;gt;iluminat.in&amp;lt;/code&amp;gt;&lt;br /&gt;
 1&lt;br /&gt;
 4 2&lt;br /&gt;
 1 2 3 4&lt;br /&gt;
 16 13 5 6&lt;br /&gt;
 12 9 7 14&lt;br /&gt;
 10 11 8 15&lt;br /&gt;
&amp;lt;code&amp;gt;iluminat.out&amp;lt;/code&amp;gt;&lt;br /&gt;
 15&lt;br /&gt;
&lt;br /&gt;
=== Explicație ===&lt;br /&gt;
Cerința este &amp;lt;code&amp;gt;1&amp;lt;/code&amp;gt;. Se sting becurile din cartierul având &amp;lt;code&amp;gt;16&amp;lt;/code&amp;gt; stâlpi de iluminat, ceea ce duce la stingerea becurilor de pe stâlpii din linia &amp;lt;code&amp;gt;2&amp;lt;/code&amp;gt; și din coloana &amp;lt;code&amp;gt;1&amp;lt;/code&amp;gt;. Tabloul devine:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;code&amp;gt;0  2  3  4&amp;lt;/code&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;code&amp;gt;0  0  0  0&amp;lt;/code&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;code&amp;gt;0  9  7 14&amp;lt;/code&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;code&amp;gt;0 11  8 15&amp;lt;/code&amp;gt;&lt;br /&gt;
&lt;br /&gt;
La etapa a doua, primul cartier în care se sting becurile are &amp;lt;code&amp;gt;15&amp;lt;/code&amp;gt; stâlpi de iluminat.&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;python&amp;quot; line=&amp;quot;1&amp;quot;&amp;gt;&lt;br /&gt;
import numpy as np&lt;br /&gt;
&lt;br /&gt;
def generate_matrix(n):&lt;br /&gt;
    return np.arange(1, n*n + 1).reshape(n, n)&lt;br /&gt;
&lt;br /&gt;
def find_max_and_sting(matrix):&lt;br /&gt;
    max_value = np.max(matrix)&lt;br /&gt;
    max_index = np.unravel_index(np.argmax(matrix, axis=None), matrix.shape)&lt;br /&gt;
    row, col = max_index&lt;br /&gt;
    matrix[row, :] = 0&lt;br /&gt;
    matrix[:, col] = 0&lt;br /&gt;
    return max_value, np.count_nonzero(matrix == 0)&lt;br /&gt;
&lt;br /&gt;
def max_bulbs_in_kxk(matrix, k):&lt;br /&gt;
    max_sum = 0&lt;br /&gt;
    for i in range(matrix.shape[0] - k + 1):&lt;br /&gt;
        for j in range(matrix.shape[1] - k + 1):&lt;br /&gt;
            submatrix_sum = np.sum(matrix[i:i+k, j:j+k])&lt;br /&gt;
            if submatrix_sum &amp;gt; max_sum:&lt;br /&gt;
                max_sum = submatrix_sum&lt;br /&gt;
    return max_sum&lt;br /&gt;
&lt;br /&gt;
def stage_results(n, k):&lt;br /&gt;
    matrix = generate_matrix(n)&lt;br /&gt;
    original_matrix = matrix.copy()&lt;br /&gt;
    &lt;br /&gt;
    max_value_at_k = 0&lt;br /&gt;
    total_sting_at_k = 0&lt;br /&gt;
    &lt;br /&gt;
    for stage in range(1, k + 1):&lt;br /&gt;
        max_value, sting_count = find_max_and_sting(matrix)&lt;br /&gt;
        if stage == k:&lt;br /&gt;
            max_value_at_k = max_value&lt;br /&gt;
            total_sting_at_k = sting_count&lt;br /&gt;
&lt;br /&gt;
    max_in_kxk_before_sting = max_bulbs_in_kxk(original_matrix, k)&lt;br /&gt;
    &lt;br /&gt;
    return max_value_at_k, total_sting_at_k, max_in_kxk_before_sting&lt;br /&gt;
&lt;br /&gt;
# Citirea datelor de intrare&lt;br /&gt;
n = int(input())&lt;br /&gt;
k = int(input())&lt;br /&gt;
&lt;br /&gt;
# Calcularea și afișarea rezultatelor&lt;br /&gt;
max_value_at_k, total_sting_at_k, max_in_kxk_before_sting = stage_results(n, k)&lt;br /&gt;
&lt;br /&gt;
print(max_value_at_k)&lt;br /&gt;
print(total_sting_at_k)&lt;br /&gt;
print(max_in_kxk_before_sting)&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;/div&gt;</summary>
		<author><name>RaulOtet</name></author>
	</entry>
</feed>